mirror of
https://gitlab.freedesktop.org/gstreamer/gstreamer.git
synced 2025-01-05 15:08:48 +00:00
GST_DEBUG reorganization containing loads of stuff:
Original commit message from CVS: GST_DEBUG reorganization This is a big diff (ca 450k), containing loads of stuff: - gstinfo.[ch] complete rewrite - changing of all GST_DEBUG messages to reflect that change - reorganization of subsystem disabling - addition of gstconfig.h.in so we can track the disablings - <gst/gst.h> does not include <unistd.h> and <config.h> anymore - documentation updated for gstinfo stuff (build the docs yourself to know what changed) - bugfixes for making of the docs (files from CVS are not deleted anymore - testsuite for debugging changes in testsuite/debug expect breakage
This commit is contained in:
parent
30438fd472
commit
803ce6bf48
190 changed files with 4716 additions and 2581 deletions
2
common
2
common
|
@ -1 +1 @@
|
||||||
Subproject commit 4e379694ae9ff9843d65cf08928642eea44abdf8
|
Subproject commit 2a3efdc282fb1ecfd2720dea40523b3441f10fed
|
19
configure.ac
19
configure.ac
|
@ -255,8 +255,6 @@ AC_HELP_STRING([--enable-plugin-builddir],[allow tests/demos to use non-installe
|
||||||
esac],
|
esac],
|
||||||
[PLUGINS_USE_BUILDDIR=no]) dnl Default value
|
[PLUGINS_USE_BUILDDIR=no]) dnl Default value
|
||||||
|
|
||||||
GST_DEBUGINFO
|
|
||||||
|
|
||||||
AC_ARG_ENABLE(profiling,
|
AC_ARG_ENABLE(profiling,
|
||||||
AC_HELP_STRING([--enable-profiling],[adds -pg to compiler commandline, for profiling]),
|
AC_HELP_STRING([--enable-profiling],[adds -pg to compiler commandline, for profiling]),
|
||||||
[case "${enableval}" in
|
[case "${enableval}" in
|
||||||
|
@ -327,6 +325,18 @@ AM_CONDITIONAL(BUILD_EXAMPLES, test "x$BUILD_EXAMPLES" = "xyes")
|
||||||
dnl Next, check for the optional components:
|
dnl Next, check for the optional components:
|
||||||
dnl ========================================
|
dnl ========================================
|
||||||
|
|
||||||
|
dnl debugging stuff
|
||||||
|
AC_ARG_ENABLE(debug,
|
||||||
|
AC_HELP_STRING([--disable-debug],[disable addition of -g debugging info]),
|
||||||
|
[case "${enableval}" in
|
||||||
|
yes) USE_DEBUG=yes ;;
|
||||||
|
no) USE_DEBUG=no ;;
|
||||||
|
*) AC_MSG_ERROR(bad value ${enableval} for --enable-debug) ;;
|
||||||
|
esac],
|
||||||
|
[USE_DEBUG=yes]) dnl Default value
|
||||||
|
translit(dnm, m, l) AM_CONDITIONAL(GST_DISABLE_GST_DEBUG, true)
|
||||||
|
GST_SUBSYSTEM_DISABLE(GST_DEBUG,[debugging subsystem])
|
||||||
|
|
||||||
translit(dnm, m, l) AM_CONDITIONAL(GST_DISABLE_LOADSAVE, true)
|
translit(dnm, m, l) AM_CONDITIONAL(GST_DISABLE_LOADSAVE, true)
|
||||||
GST_SUBSYSTEM_DISABLE(LOADSAVE,[pipeline XML load/save])
|
GST_SUBSYSTEM_DISABLE(LOADSAVE,[pipeline XML load/save])
|
||||||
translit(dnm, m, l) AM_CONDITIONAL(GST_DISABLE_TYPEFIND, true)
|
translit(dnm, m, l) AM_CONDITIONAL(GST_DISABLE_TYPEFIND, true)
|
||||||
|
@ -351,8 +361,6 @@ GST_SUBSYSTEM_DISABLE(PLUGIN,[plugin])
|
||||||
translit(dnm, m, l) AM_CONDITIONAL(GST_DISABLE_URI, true)
|
translit(dnm, m, l) AM_CONDITIONAL(GST_DISABLE_URI, true)
|
||||||
GST_SUBSYSTEM_DISABLE(URI,[uri handlers])
|
GST_SUBSYSTEM_DISABLE(URI,[uri handlers])
|
||||||
|
|
||||||
GST_EXT_CFLAGS="$GST_EXT_CFLAGS $GST_SUBSYSTEM_DISABLE_DEFINES"
|
|
||||||
|
|
||||||
dnl ################################################
|
dnl ################################################
|
||||||
dnl # Set defines according to variables set above #
|
dnl # Set defines according to variables set above #
|
||||||
dnl ################################################
|
dnl ################################################
|
||||||
|
@ -514,6 +522,7 @@ AC_OUTPUT(
|
||||||
Makefile
|
Makefile
|
||||||
include/Makefile
|
include/Makefile
|
||||||
gst/Makefile
|
gst/Makefile
|
||||||
|
gst/gstconfig.h
|
||||||
gst/gstversion.h
|
gst/gstversion.h
|
||||||
gst/autoplug/Makefile
|
gst/autoplug/Makefile
|
||||||
gst/indexers/Makefile
|
gst/indexers/Makefile
|
||||||
|
@ -541,6 +550,7 @@ testsuite/bytestream/Makefile
|
||||||
testsuite/caps/Makefile
|
testsuite/caps/Makefile
|
||||||
testsuite/cleanup/Makefile
|
testsuite/cleanup/Makefile
|
||||||
testsuite/clock/Makefile
|
testsuite/clock/Makefile
|
||||||
|
testsuite/debug/Makefile
|
||||||
testsuite/dynparams/Makefile
|
testsuite/dynparams/Makefile
|
||||||
testsuite/elements/Makefile
|
testsuite/elements/Makefile
|
||||||
testsuite/indexers/Makefile
|
testsuite/indexers/Makefile
|
||||||
|
@ -569,7 +579,6 @@ tools/Makefile
|
||||||
docs/Makefile
|
docs/Makefile
|
||||||
docs/faq/Makefile
|
docs/faq/Makefile
|
||||||
docs/gst/Makefile
|
docs/gst/Makefile
|
||||||
docs/gst/gstreamer.types
|
|
||||||
docs/libs/Makefile
|
docs/libs/Makefile
|
||||||
docs/manual/Makefile
|
docs/manual/Makefile
|
||||||
docs/pwg/Makefile
|
docs/pwg/Makefile
|
||||||
|
|
|
@ -113,6 +113,7 @@ DOC_STAMPS=scan-build.stamp tmpl-build.stamp sgml-build.stamp html-build.stamp \
|
||||||
SCANOBJ_FILES = \
|
SCANOBJ_FILES = \
|
||||||
$(DOC_MODULE).args \
|
$(DOC_MODULE).args \
|
||||||
$(DOC_MODULE).hierarchy \
|
$(DOC_MODULE).hierarchy \
|
||||||
|
$(DOC_MODULE)-scan.o \
|
||||||
$(DOC_MODULE).signals
|
$(DOC_MODULE).signals
|
||||||
|
|
||||||
if HAVE_GTK_DOC
|
if HAVE_GTK_DOC
|
||||||
|
@ -182,12 +183,15 @@ clean-local:
|
||||||
maintainer-clean-local: clean
|
maintainer-clean-local: clean
|
||||||
cd $(srcdir) && rm -rf sgml html $(DOC_MODULE)-decl-list.txt $(DOC_MODULE)-decl.txt
|
cd $(srcdir) && rm -rf sgml html $(DOC_MODULE)-decl-list.txt $(DOC_MODULE)-decl.txt
|
||||||
|
|
||||||
|
# company: don't delete .sgml and -sections.txt as they're in CVS
|
||||||
# FIXME : thomas added all sgml files and some other things to make
|
# FIXME : thomas added all sgml files and some other things to make
|
||||||
# make distcheck work
|
# make distcheck work
|
||||||
distclean-local: clean
|
distclean-local: clean
|
||||||
rm -rf $(DOC_MODULE)-decl-list.txt
|
rm -rf $(DOC_MODULE)-decl-list.txt
|
||||||
rm -rf $(DOC_MODULE)-*.txt
|
rm -rf $(DOC_MODULE)-decl.txt
|
||||||
rm -rf tmpl/*.sgml
|
rm -rf $(DOC_MODULE)-undocumented.txt
|
||||||
|
rm -rf $(DOC_MODULE)-unused.txt
|
||||||
|
rm -rf tmpl/*.sgml.bak
|
||||||
rm -f $(DOC_MODULE).hierarchy
|
rm -f $(DOC_MODULE).hierarchy
|
||||||
rm -f *.stamp || true
|
rm -f *.stamp || true
|
||||||
|
|
||||||
|
|
|
@ -3,23 +3,21 @@
|
||||||
"http://www.oasis-open.org/docbook/xml/4.1.2/docbookx.dtd" [
|
"http://www.oasis-open.org/docbook/xml/4.1.2/docbookx.dtd" [
|
||||||
<!ENTITY Gst SYSTEM "xml/gst.xml">
|
<!ENTITY Gst SYSTEM "xml/gst.xml">
|
||||||
<!ENTITY GstAutoplug SYSTEM "xml/gstautoplug.xml">
|
<!ENTITY GstAutoplug SYSTEM "xml/gstautoplug.xml">
|
||||||
<!ENTITY GstAutoplugFactory SYSTEM "xml/gstautoplugfactory.xml">
|
|
||||||
<!ENTITY GstAtomic SYSTEM "xml/gstatomic.xml">
|
<!ENTITY GstAtomic SYSTEM "xml/gstatomic.xml">
|
||||||
<!ENTITY GstBin SYSTEM "xml/gstbin.xml">
|
<!ENTITY GstBin SYSTEM "xml/gstbin.xml">
|
||||||
|
<!ENTITY GstConfig SYSTEM "xml/gstconfig.xml">
|
||||||
<!ENTITY GstData SYSTEM "xml/gstdata.xml">
|
<!ENTITY GstData SYSTEM "xml/gstdata.xml">
|
||||||
<!ENTITY GstBuffer SYSTEM "xml/gstbuffer.xml">
|
<!ENTITY GstBuffer SYSTEM "xml/gstbuffer.xml">
|
||||||
<!ENTITY GstEvent SYSTEM "xml/gstevent.xml">
|
<!ENTITY GstEvent SYSTEM "xml/gstevent.xml">
|
||||||
<!ENTITY GstBufferPool SYSTEM "xml/gstbufferpool.xml">
|
<!ENTITY GstBufferPool SYSTEM "xml/gstbuffer.xml">
|
||||||
<!ENTITY GstCpu SYSTEM "xml/gstcpu.xml">
|
<!ENTITY GstCpu SYSTEM "xml/gstcpu.xml">
|
||||||
<!ENTITY GstElement SYSTEM "xml/gstelement.xml">
|
<!ENTITY GstElement SYSTEM "xml/gstelement.xml">
|
||||||
<!ENTITY GstElementFactory SYSTEM "xml/gstelementfactory.xml">
|
|
||||||
<!ENTITY GstFormat SYSTEM "xml/gstformat.xml">
|
<!ENTITY GstFormat SYSTEM "xml/gstformat.xml">
|
||||||
<!ENTITY GstInfo SYSTEM "xml/gstinfo.xml">
|
<!ENTITY GstInfo SYSTEM "xml/gstinfo.xml">
|
||||||
<!ENTITY GstLog SYSTEM "xml/gstlog.xml">
|
<!ENTITY GstLog SYSTEM "xml/gstlog.xml">
|
||||||
<!ENTITY GstMemChunk SYSTEM "xml/gstmemchunk.xml">
|
<!ENTITY GstMemChunk SYSTEM "xml/gstmemchunk.xml">
|
||||||
<!ENTITY GstObject SYSTEM "xml/gstobject.xml">
|
<!ENTITY GstObject SYSTEM "xml/gstobject.xml">
|
||||||
<!ENTITY GstPad SYSTEM "xml/gstpad.xml">
|
<!ENTITY GstPad SYSTEM "xml/gstpad.xml">
|
||||||
<!ENTITY GstPadTemplate SYSTEM "xml/gstpadtemplate.xml">
|
|
||||||
<!ENTITY GstParse SYSTEM "xml/gstparse.xml">
|
<!ENTITY GstParse SYSTEM "xml/gstparse.xml">
|
||||||
<!ENTITY GstProbe SYSTEM "xml/gstprobe.xml">
|
<!ENTITY GstProbe SYSTEM "xml/gstprobe.xml">
|
||||||
<!ENTITY GstPipeline SYSTEM "xml/gstpipeline.xml">
|
<!ENTITY GstPipeline SYSTEM "xml/gstpipeline.xml">
|
||||||
|
@ -30,10 +28,9 @@
|
||||||
<!ENTITY GstRegistry SYSTEM "xml/gstregistry.xml">
|
<!ENTITY GstRegistry SYSTEM "xml/gstregistry.xml">
|
||||||
<!ENTITY GstRegistryPool SYSTEM "xml/gstregistrypool.xml">
|
<!ENTITY GstRegistryPool SYSTEM "xml/gstregistrypool.xml">
|
||||||
<!ENTITY GstScheduler SYSTEM "xml/gstscheduler.xml">
|
<!ENTITY GstScheduler SYSTEM "xml/gstscheduler.xml">
|
||||||
<!ENTITY GstSchedulerFactory SYSTEM "xml/gstschedulerfactory.xml">
|
|
||||||
<!ENTITY GstTrace SYSTEM "xml/gsttrace.xml">
|
<!ENTITY GstTrace SYSTEM "xml/gsttrace.xml">
|
||||||
<!ENTITY GstType SYSTEM "xml/gsttype.xml">
|
<!ENTITY GstType SYSTEM "xml/gsttype.xml">
|
||||||
<!ENTITY GstTypeFactory SYSTEM "xml/gsttypefactory.xml">
|
<!ENTITY GstTypeFactory SYSTEM "xml/gsttype.xml">
|
||||||
<!ENTITY GstCaps SYSTEM "xml/gstcaps.xml">
|
<!ENTITY GstCaps SYSTEM "xml/gstcaps.xml">
|
||||||
<!ENTITY GstProps SYSTEM "xml/gstprops.xml">
|
<!ENTITY GstProps SYSTEM "xml/gstprops.xml">
|
||||||
<!ENTITY GstClock SYSTEM "xml/gstclock.xml">
|
<!ENTITY GstClock SYSTEM "xml/gstclock.xml">
|
||||||
|
@ -46,7 +43,6 @@
|
||||||
<!ENTITY GstTypeFind SYSTEM "xml/gsttypefind.xml">
|
<!ENTITY GstTypeFind SYSTEM "xml/gsttypefind.xml">
|
||||||
-->
|
-->
|
||||||
<!ENTITY GstIndex SYSTEM "xml/gstindex.xml">
|
<!ENTITY GstIndex SYSTEM "xml/gstindex.xml">
|
||||||
<!ENTITY GstIndexFactory SYSTEM "xml/gstindexfactory.xml">
|
|
||||||
<!ENTITY cothreads SYSTEM "xml/cothreads.xml">
|
<!ENTITY cothreads SYSTEM "xml/cothreads.xml">
|
||||||
|
|
||||||
<!-- if none of the API is documented, these shouldn't go in
|
<!-- if none of the API is documented, these shouldn't go in
|
||||||
|
@ -67,6 +63,8 @@
|
||||||
<!ENTITY GstTee SYSTEM "xml/gsttee.xml">
|
<!ENTITY GstTee SYSTEM "xml/gsttee.xml">
|
||||||
|
|
||||||
<!ENTITY gstreamer-tree-index SYSTEM "xml/tree_index.xml">
|
<!ENTITY gstreamer-tree-index SYSTEM "xml/tree_index.xml">
|
||||||
|
|
||||||
|
<!ENTITY hash "#">
|
||||||
]>
|
]>
|
||||||
<book>
|
<book>
|
||||||
<bookinfo>
|
<bookinfo>
|
||||||
|
@ -92,24 +90,20 @@ with some more specialized elements.</para>
|
||||||
|
|
||||||
&Gst;
|
&Gst;
|
||||||
&GstAutoplug;
|
&GstAutoplug;
|
||||||
&GstAutoplugFactory;
|
|
||||||
&GstBin;
|
&GstBin;
|
||||||
&GstBuffer;
|
&GstBuffer;
|
||||||
&GstBufferPool;
|
&GstConfig;
|
||||||
&GstCaps;
|
&GstCaps;
|
||||||
&GstClock;
|
&GstClock;
|
||||||
&GstCpu;
|
&GstCpu;
|
||||||
&GstData;
|
&GstData;
|
||||||
&GstElement;
|
&GstElement;
|
||||||
&GstElementFactory;
|
|
||||||
&GstEvent;
|
&GstEvent;
|
||||||
&GstFormat;
|
&GstFormat;
|
||||||
&GstIndex;
|
&GstIndex;
|
||||||
&GstIndexFactory;
|
|
||||||
&GstInfo;
|
&GstInfo;
|
||||||
&GstObject;
|
&GstObject;
|
||||||
&GstPad;
|
&GstPad;
|
||||||
&GstPadTemplate;
|
|
||||||
&GstParse;
|
&GstParse;
|
||||||
&GstPipeline;
|
&GstPipeline;
|
||||||
&GstPlugin;
|
&GstPlugin;
|
||||||
|
@ -122,11 +116,9 @@ with some more specialized elements.</para>
|
||||||
&GstRegistry;
|
&GstRegistry;
|
||||||
&GstRegistryPool;
|
&GstRegistryPool;
|
||||||
&GstScheduler;
|
&GstScheduler;
|
||||||
&GstSchedulerFactory;
|
|
||||||
&GstSystemClock;
|
&GstSystemClock;
|
||||||
&GstThread;
|
&GstThread;
|
||||||
&GstType;
|
&GstType;
|
||||||
&GstTypeFactory;
|
|
||||||
<!-- no API docs
|
<!-- no API docs
|
||||||
&GstTypeFind; -->
|
&GstTypeFind; -->
|
||||||
&GstUri;
|
&GstUri;
|
||||||
|
|
|
@ -82,41 +82,72 @@ gst_marshal_VOID__VOID
|
||||||
|
|
||||||
<SECTION>
|
<SECTION>
|
||||||
<FILE>gstinfo</FILE>
|
<FILE>gstinfo</FILE>
|
||||||
<TITLE>GstInfo</TITLE>
|
GST_STR_NULL
|
||||||
gst_get_category_name
|
GST_DEBUG_PAD_NAME
|
||||||
gst_info_get_categories
|
GST_FUNCTION
|
||||||
gst_info_set_categories
|
<SUBSECTION>
|
||||||
gst_info_enable_category
|
GstDebugLevel
|
||||||
gst_info_disable_category
|
GST_LEVEL_DEFAULT
|
||||||
gst_default_info_handler
|
gst_debug_level_get_name
|
||||||
GST_INFO_ENABLED
|
GstDebugColorFlags
|
||||||
|
gst_debug_construct_term_color
|
||||||
|
GstDebugCategory
|
||||||
|
GST_CAT_DEFAULT
|
||||||
|
<SUBSECTION>
|
||||||
|
GstLogFunction
|
||||||
|
gst_debug_log
|
||||||
|
gst_debug_logv
|
||||||
|
gst_debug_log_default
|
||||||
|
gst_debug_add_log_function
|
||||||
|
gst_debug_remove_log_function
|
||||||
|
gst_debug_remove_log_function_by_data
|
||||||
|
<SUBSECTION>
|
||||||
|
gst_debug_set_active
|
||||||
|
gst_debug_is_active
|
||||||
|
gst_debug_set_colored
|
||||||
|
gst_debug_is_colored
|
||||||
|
gst_debug_set_default_threshold
|
||||||
|
gst_debug_get_default_threshold
|
||||||
|
gst_debug_set_threshold_for_name
|
||||||
|
gst_debug_unset_threshold_for_name
|
||||||
|
<SUBSECTION>
|
||||||
|
GST_DEBUG_CATEGORY
|
||||||
|
GST_DEBUG_CATEGORY_EXTERN
|
||||||
|
GST_DEBUG_CATEGORY_STATIC
|
||||||
|
GST_DEBUG_CATEGORY_INIT
|
||||||
|
gst_debug_category_free
|
||||||
|
gst_debug_category_set_threshold
|
||||||
|
gst_debug_category_reset_threshold
|
||||||
|
gst_debug_category_get_threshold
|
||||||
|
gst_debug_category_get_name
|
||||||
|
gst_debug_category_get_color
|
||||||
|
gst_debug_category_get_description
|
||||||
|
gst_debug_get_all_categories
|
||||||
|
<SUBSECTION>
|
||||||
|
GST_CAT_LEVEL_LOG
|
||||||
GST_INFO
|
GST_INFO
|
||||||
GST_INFO_ELEMENT
|
|
||||||
gst_debug_get_categories
|
|
||||||
gst_debug_set_categories
|
|
||||||
gst_debug_enable_category
|
|
||||||
gst_debug_disable_category
|
|
||||||
GST_DEBUG_ENTER
|
|
||||||
GST_DEBUG_LEAVE
|
|
||||||
GST_DEBUG
|
GST_DEBUG
|
||||||
|
GST_CAT_ERROR_OBJECT
|
||||||
|
GST_CAT_WARNING_OBJECT
|
||||||
|
GST_CAT_INFO_OBJECT
|
||||||
|
GST_CAT_DEBUG_OBJECT
|
||||||
|
GST_CAT_LOG_OBJECT
|
||||||
|
GST_CAT_ERROR
|
||||||
|
GST_CAT_WARNING
|
||||||
|
GST_CAT_LOG
|
||||||
|
GST_ERROR_OBJECT
|
||||||
|
GST_WARNING_OBJECT
|
||||||
|
GST_INFO_OBJECT
|
||||||
|
GST_DEBUG_OBJECT
|
||||||
|
GST_LOG_OBJECT
|
||||||
|
GST_ERROR
|
||||||
|
GST_WARNING
|
||||||
|
GST_CAT_INFO
|
||||||
|
GST_CAT_DEBUG
|
||||||
|
GST_LOG
|
||||||
|
<SUBSECTION>
|
||||||
GST_DEBUG_FUNCPTR
|
GST_DEBUG_FUNCPTR
|
||||||
GST_DEBUG_FUNCPTR_NAME
|
GST_DEBUG_FUNCPTR_NAME
|
||||||
GST_DEBUG_PAD_NAME
|
|
||||||
GST_DEBUG_THREAD_ARGS
|
|
||||||
GST_DEBUG_THREAD_FORMAT
|
|
||||||
GST_DEBUG_ELEMENT
|
|
||||||
GST_ERROR
|
|
||||||
GST_ERROR_OBJECT
|
|
||||||
GstDebugHandler
|
|
||||||
gst_default_debug_handler
|
|
||||||
gst_default_error_handler
|
|
||||||
GstInfoHandler
|
|
||||||
GstErrorHandler
|
|
||||||
<SUBSECTION Standard>
|
|
||||||
gst_debug_print_stack_trace
|
|
||||||
GST_DEBUG_CHAR_MODE
|
|
||||||
GST_DEBUG_ENABLED
|
|
||||||
GST_DEBUG_ENABLE_CATEGORIES
|
|
||||||
</SECTION>
|
</SECTION>
|
||||||
|
|
||||||
<SECTION>
|
<SECTION>
|
||||||
|
@ -166,6 +197,23 @@ GST_SCHEDULER_FACTORY_GET_CLASS
|
||||||
GST_SCHEDULER_GET_CLASS
|
GST_SCHEDULER_GET_CLASS
|
||||||
</SECTION>
|
</SECTION>
|
||||||
|
|
||||||
|
<SECTION>
|
||||||
|
<FILE>gstconfig</FILE>
|
||||||
|
GST_DISABLE_ALLOC_TRACE
|
||||||
|
GST_DISABLE_AUTOPLUG
|
||||||
|
GST_DISABLE_ENUMTYPES
|
||||||
|
GST_DISABLE_GST_DEBUG
|
||||||
|
GST_DISABLE_INDEX
|
||||||
|
GST_DISABLE_LOADSAVE
|
||||||
|
GST_DISABLE_LOADSAVE_REGISTRY
|
||||||
|
GST_DISABLE_PARSE
|
||||||
|
GST_DISABLE_PLUGIN
|
||||||
|
GST_DISABLE_TRACE
|
||||||
|
GST_DISABLE_TYPEFIND
|
||||||
|
GST_DISABLE_URI
|
||||||
|
GST_DISABLE_REGISTRY
|
||||||
|
</SECTION>
|
||||||
|
|
||||||
<SECTION>
|
<SECTION>
|
||||||
<FILE>gstschedulerfactory</FILE>
|
<FILE>gstschedulerfactory</FILE>
|
||||||
<TITLE>GstSchedulerFactory</TITLE>
|
<TITLE>GstSchedulerFactory</TITLE>
|
||||||
|
|
131
docs/gst/tmpl/gstconfig.sgml
Normal file
131
docs/gst/tmpl/gstconfig.sgml
Normal file
|
@ -0,0 +1,131 @@
|
||||||
|
<!-- ##### SECTION Title ##### -->
|
||||||
|
GstConfig
|
||||||
|
|
||||||
|
<!-- ##### SECTION Short_Description ##### -->
|
||||||
|
configuration options
|
||||||
|
|
||||||
|
<!-- ##### SECTION Long_Description ##### -->
|
||||||
|
<para>
|
||||||
|
This describes the configureation options for GStreamer. When building
|
||||||
|
GStreamer there are a lot of parts (known internally as "subsystems" ) that can
|
||||||
|
be disabled for various reasons. The most common reasons are speed and size,
|
||||||
|
which is important because GStreamer is designed to run on embedded systems.
|
||||||
|
</para>
|
||||||
|
|
||||||
|
<para>
|
||||||
|
If a subsystem is disabled, most of this changes are done in an API compatible
|
||||||
|
way, so you don't need to adapt your code in most cases. It is never done in an
|
||||||
|
ABI compatible way though. So if you want to disable a suybsystem, you have to
|
||||||
|
rebuild all programs depending on GStreamer, too.
|
||||||
|
</para>
|
||||||
|
|
||||||
|
<para>
|
||||||
|
If a subsystem is disabled in GStreamer, a value is defined in
|
||||||
|
<gst/gst.h>. You can check this if you do subsystem-specific stuff.
|
||||||
|
<example>
|
||||||
|
<title>Doing subsystem specific things</title>
|
||||||
|
<programlisting>
|
||||||
|
&hash;ifndef GST_DISABLE_GST_DEBUG
|
||||||
|
/* do stuff specific to the debugging subsystem */
|
||||||
|
&hash;endif /* GST_DISABLE_GST_DEBUG */
|
||||||
|
</programlisting>
|
||||||
|
</example>
|
||||||
|
</para>
|
||||||
|
|
||||||
|
<!-- ##### SECTION See_Also ##### -->
|
||||||
|
<para>
|
||||||
|
|
||||||
|
</para>
|
||||||
|
|
||||||
|
<!-- ##### MACRO GST_DISABLE_LOADSAVE_REGISTRY ##### -->
|
||||||
|
<para>
|
||||||
|
|
||||||
|
</para>
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
<!-- ##### MACRO GST_DISABLE_GST_DEBUG ##### -->
|
||||||
|
<para>
|
||||||
|
If this is defined, the <link linkend="gstreamer-gstinfo">debugging subsystem
|
||||||
|
</link> is disabled and debugging messages are not output.
|
||||||
|
</para>
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
<!-- ##### MACRO GST_DISABLE_LOADSAVE ##### -->
|
||||||
|
<para>
|
||||||
|
|
||||||
|
</para>
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
<!-- ##### MACRO GST_DISABLE_TYPEFIND ##### -->
|
||||||
|
<para>
|
||||||
|
|
||||||
|
</para>
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
<!-- ##### MACRO GST_DISABLE_AUTOPLUG ##### -->
|
||||||
|
<para>
|
||||||
|
|
||||||
|
</para>
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
<!-- ##### MACRO GST_DISABLE_PARSE ##### -->
|
||||||
|
<para>
|
||||||
|
|
||||||
|
</para>
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
<!-- ##### MACRO GST_DISABLE_TRACE ##### -->
|
||||||
|
<para>
|
||||||
|
|
||||||
|
</para>
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
<!-- ##### MACRO GST_DISABLE_ALLOC_TRACE ##### -->
|
||||||
|
<para>
|
||||||
|
|
||||||
|
</para>
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
<!-- ##### MACRO GST_DISABLE_REGISTRY ##### -->
|
||||||
|
<para>
|
||||||
|
|
||||||
|
</para>
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
<!-- ##### MACRO GST_DISABLE_ENUMTYPES ##### -->
|
||||||
|
<para>
|
||||||
|
|
||||||
|
</para>
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
<!-- ##### MACRO GST_DISABLE_INDEX ##### -->
|
||||||
|
<para>
|
||||||
|
|
||||||
|
</para>
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
<!-- ##### MACRO GST_DISABLE_PLUGIN ##### -->
|
||||||
|
<para>
|
||||||
|
|
||||||
|
</para>
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
<!-- ##### MACRO GST_DISABLE_URI ##### -->
|
||||||
|
<para>
|
||||||
|
|
||||||
|
</para>
|
||||||
|
|
||||||
|
|
||||||
|
|
|
@ -2,315 +2,668 @@
|
||||||
GstInfo
|
GstInfo
|
||||||
|
|
||||||
<!-- ##### SECTION Short_Description ##### -->
|
<!-- ##### SECTION Short_Description ##### -->
|
||||||
info/debugging/error handling
|
debugging subsystem
|
||||||
|
|
||||||
<!-- ##### SECTION Long_Description ##### -->
|
<!-- ##### SECTION Long_Description ##### -->
|
||||||
<para>
|
<para>
|
||||||
gstinfo.c contains a number of debuggins subsystems.
|
This file describes the debugging subsystem. The debugging subsystem works
|
||||||
|
only after GStreamer was initilized - for example by calling #gst_init.
|
||||||
</para>
|
</para>
|
||||||
|
|
||||||
<para>The INFO subsystem is used to provide informative printouts to
|
<para>
|
||||||
application and plugin developers. These messages can be enabled and
|
The debugging subsystem is used to send informational strings to the debugging
|
||||||
disabled via a category system, which is a bitmask enabling you to turn
|
developer. Each messages has some properties attached to it. These properties
|
||||||
on and off any subset of categories.</para>
|
are the debugging category, the severity (called "level" here) and an obtional
|
||||||
|
#GObject it belongs to. Each of these messages is sent to all registered
|
||||||
<para>The DEBUG subsystem is similar, but is intended for core developers
|
debugging handlers, which then handle the messages. GStreamer attaches a
|
||||||
and those writing more complex pipelines or filters. It uses the same
|
default handler on startup, which outputs requested messages to stderr.
|
||||||
category system, but must be enabled at configure time else it's not
|
|
||||||
compiled into the library. autogen.sh automatically enables the DEBUG
|
|
||||||
subsystem.
|
|
||||||
</para>
|
</para>
|
||||||
|
|
||||||
<para>The ERROR subsystem doesn't use categories, but will print out a
|
<para>
|
||||||
more verbose message, and attempt to print out a stack trace of the error
|
Messages are output by using shortcut macros like #GST_DEBUG,
|
||||||
before aborting the application.
|
#GST_CAT_ERROR_OBJECT or similar. These all expand to calling #gst_debug_log
|
||||||
|
with the right parameters.
|
||||||
|
The only thing a developer will probably want to do is define his own
|
||||||
|
categories. This is easily done with 3 lines. At the top of your code, declare
|
||||||
|
the variables and set the default category.
|
||||||
|
<informalexample>
|
||||||
|
<programlisting>
|
||||||
|
GST_DEBUG_CATEGORY (my_category); /* define category */
|
||||||
|
&hash;define GST_CAT_DEFAULT my_category /* set as default */
|
||||||
|
</programlisting>
|
||||||
|
</informalexample>
|
||||||
|
After that you only need to initialize the category.
|
||||||
|
<informalexample>
|
||||||
|
<programlisting>
|
||||||
|
GST_DEBUG_CATEGORY_INIT (my_category, "my category", 0, "This is my very own");
|
||||||
|
</programlisting>
|
||||||
|
</informalexample>
|
||||||
|
Initialization must be done before the category is used first. Plugins do this
|
||||||
|
in their plugin_init function, libraries and applications should do that
|
||||||
|
during their initialization.
|
||||||
|
</para>
|
||||||
|
|
||||||
|
<para>
|
||||||
|
The whole debugging subsystem can be disabled at build time with passing the
|
||||||
|
--disable-gst-debug switch to configure. If this is done, every function, macro
|
||||||
|
and even structs described in this file evaluate to default values or nothing
|
||||||
|
at all. So don't take addresses of these functions or use other tricks.
|
||||||
|
If you must do that for some reason, there is still an option. If the debugging
|
||||||
|
subsystem was compiled out, #GST_DISABLE_GST_DEBUG is defined in <gst/gst.h>,
|
||||||
|
so you can check that before doing your trick.
|
||||||
|
Disabling the debugging subsystem will give you a slight (read: unnoticable)
|
||||||
|
speed increase and will reduce the size of your compiled code. The GStreamer
|
||||||
|
library itself becomes around 10% smaller.
|
||||||
|
</para>
|
||||||
|
|
||||||
|
<para>
|
||||||
|
Please note that there are naming conventions for the names of debugging
|
||||||
|
categories. These are explained at GST_DEBUG_CATEGORY_INIT().
|
||||||
</para>
|
</para>
|
||||||
|
|
||||||
<!-- ##### SECTION See_Also ##### -->
|
<!-- ##### SECTION See_Also ##### -->
|
||||||
<para>
|
<para>
|
||||||
|
<link linkend="gstreamer-gstconfig">configuration</link>,
|
||||||
|
<link linkend="gstreamer-gst">initialization</link> for command line parameters
|
||||||
|
and environment variables that affect the debugging output.
|
||||||
</para>
|
</para>
|
||||||
|
|
||||||
<!-- ##### FUNCTION gst_get_category_name ##### -->
|
<!-- ##### MACRO GST_STR_NULL ##### -->
|
||||||
<para>
|
<para>
|
||||||
|
Macro to use when a string must not be NULL, but may be NULL. If the string is
|
||||||
|
NULL, "(NULL)" is printed instead.
|
||||||
|
In GStreamer printf string arguments may not be NULL, because on some platforms
|
||||||
|
(ie Solaris) the libc crashes in that case. This includes debugging strings.
|
||||||
</para>
|
</para>
|
||||||
|
|
||||||
@category:
|
@str: The string to check.
|
||||||
@Returns:
|
@Returns: A string that is guaranteed to be not NULL.
|
||||||
|
|
||||||
|
|
||||||
<!-- ##### FUNCTION gst_info_get_categories ##### -->
|
|
||||||
<para>
|
|
||||||
|
|
||||||
</para>
|
|
||||||
|
|
||||||
@Returns:
|
|
||||||
|
|
||||||
|
|
||||||
<!-- ##### FUNCTION gst_info_set_categories ##### -->
|
|
||||||
<para>
|
|
||||||
|
|
||||||
</para>
|
|
||||||
|
|
||||||
@categories:
|
|
||||||
|
|
||||||
|
|
||||||
<!-- ##### FUNCTION gst_info_enable_category ##### -->
|
|
||||||
<para>
|
|
||||||
|
|
||||||
</para>
|
|
||||||
|
|
||||||
@category:
|
|
||||||
|
|
||||||
|
|
||||||
<!-- ##### FUNCTION gst_info_disable_category ##### -->
|
|
||||||
<para>
|
|
||||||
|
|
||||||
</para>
|
|
||||||
|
|
||||||
@category:
|
|
||||||
|
|
||||||
|
|
||||||
<!-- ##### FUNCTION gst_default_info_handler ##### -->
|
|
||||||
<para>
|
|
||||||
|
|
||||||
</para>
|
|
||||||
|
|
||||||
@category:
|
|
||||||
@incore:
|
|
||||||
@file:
|
|
||||||
@function:
|
|
||||||
@line:
|
|
||||||
@debug_string:
|
|
||||||
@element:
|
|
||||||
@string:
|
|
||||||
|
|
||||||
|
|
||||||
<!-- ##### MACRO GST_INFO_ENABLED ##### -->
|
|
||||||
<para>
|
|
||||||
When defined, INFO printouts are compiled into the library.
|
|
||||||
</para>
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
<!-- ##### MACRO GST_INFO ##### -->
|
|
||||||
<para>
|
|
||||||
Print out any information usable at run-time by application developers.
|
|
||||||
</para>
|
|
||||||
|
|
||||||
@cat: the GST_CAT_... category for the information
|
|
||||||
@...: printf arguments
|
|
||||||
|
|
||||||
|
|
||||||
<!-- ##### MACRO GST_INFO_ELEMENT ##### -->
|
|
||||||
<para>
|
|
||||||
Print out information like #GST_INFO, but with an element pointer to clarify things.
|
|
||||||
</para>
|
|
||||||
|
|
||||||
@cat: the GST_CAT_... category for the information
|
|
||||||
@element: pointer to the #GstElement in question
|
|
||||||
@...: printf arguments
|
|
||||||
|
|
||||||
|
|
||||||
<!-- ##### FUNCTION gst_debug_get_categories ##### -->
|
|
||||||
<para>
|
|
||||||
|
|
||||||
</para>
|
|
||||||
|
|
||||||
@Returns:
|
|
||||||
|
|
||||||
|
|
||||||
<!-- ##### FUNCTION gst_debug_set_categories ##### -->
|
|
||||||
<para>
|
|
||||||
|
|
||||||
</para>
|
|
||||||
|
|
||||||
@categories:
|
|
||||||
|
|
||||||
|
|
||||||
<!-- ##### FUNCTION gst_debug_enable_category ##### -->
|
|
||||||
<para>
|
|
||||||
|
|
||||||
</para>
|
|
||||||
|
|
||||||
@category:
|
|
||||||
|
|
||||||
|
|
||||||
<!-- ##### FUNCTION gst_debug_disable_category ##### -->
|
|
||||||
<para>
|
|
||||||
|
|
||||||
</para>
|
|
||||||
|
|
||||||
@category:
|
|
||||||
|
|
||||||
|
|
||||||
<!-- ##### MACRO GST_DEBUG_ENTER ##### -->
|
|
||||||
<para>
|
|
||||||
Called at the beginning of a function, it simply prints out a DEBUG string of "entering"
|
|
||||||
in addition to the given string.
|
|
||||||
</para>
|
|
||||||
|
|
||||||
@...: printf arguments
|
|
||||||
|
|
||||||
|
|
||||||
<!-- ##### MACRO GST_DEBUG_LEAVE ##### -->
|
|
||||||
<para>
|
|
||||||
Called at the end of a function, it simply prints out a DEBUG string of "leaving"
|
|
||||||
in addition to the given string.
|
|
||||||
</para>
|
|
||||||
|
|
||||||
@...: printf arguments
|
|
||||||
|
|
||||||
|
|
||||||
<!-- ##### MACRO GST_DEBUG ##### -->
|
|
||||||
<para>
|
|
||||||
Print out debugging information.
|
|
||||||
</para>
|
|
||||||
|
|
||||||
@cat: the GST_CAT_... the debug falls within
|
|
||||||
@...: printf arguments
|
|
||||||
|
|
||||||
|
|
||||||
<!-- ##### MACRO GST_DEBUG_FUNCPTR ##### -->
|
|
||||||
<para>
|
|
||||||
Add a function to the global function pointer table used for debugging.
|
|
||||||
</para>
|
|
||||||
|
|
||||||
@ptr: The pointer to add to the function table.
|
|
||||||
|
|
||||||
|
|
||||||
<!-- ##### MACRO GST_DEBUG_FUNCPTR_NAME ##### -->
|
|
||||||
<para>
|
|
||||||
Get the name of the given function pointer by looking up its name in the global
|
|
||||||
function table.
|
|
||||||
</para>
|
|
||||||
|
|
||||||
@ptr: The pointer to look up.
|
|
||||||
|
|
||||||
|
|
||||||
<!-- ##### MACRO GST_DEBUG_PAD_NAME ##### -->
|
<!-- ##### MACRO GST_DEBUG_PAD_NAME ##### -->
|
||||||
<para>
|
<para>
|
||||||
Print out debugging statements for a pad.
|
Evaluates to 2 strings, that describe the pad. Often used in debugging
|
||||||
|
statements.
|
||||||
</para>
|
</para>
|
||||||
|
|
||||||
@pad: The pad to debug.
|
@pad: The pad to debug.
|
||||||
|
|
||||||
|
|
||||||
<!-- ##### MACRO GST_DEBUG_THREAD_ARGS ##### -->
|
<!-- ##### MACRO GST_FUNCTION ##### -->
|
||||||
<para>
|
<para>
|
||||||
Part of the colorized debug functions for threads
|
This macro should evaluate to the name of the current function and be should
|
||||||
</para>
|
be defined when configuring your project, as it is compiler dependant. If it
|
||||||
|
is not defined, some default value is used. It is used to provide debugging
|
||||||
@id: The thread id.
|
output with the function name of the message.
|
||||||
|
|
||||||
|
|
||||||
<!-- ##### MACRO GST_DEBUG_THREAD_FORMAT ##### -->
|
|
||||||
<para>
|
|
||||||
Part of the colorized debug functions for threads
|
|
||||||
</para>
|
</para>
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
<!-- ##### MACRO GST_DEBUG_ELEMENT ##### -->
|
<!-- ##### ENUM GstDebugLevel ##### -->
|
||||||
<para>
|
<para>
|
||||||
Print out usefull debugging info of an element.
|
The level defines the importance of a debugging message. The more important a
|
||||||
|
message is, the greater the probability that the debugging system outputs it.
|
||||||
</para>
|
</para>
|
||||||
|
|
||||||
@cat: The category of this debugging statement.
|
@GST_LEVEL_NONE: No debugging level specified or desired. Used to deactivate
|
||||||
@element: The element to debug.
|
debugging output.
|
||||||
@...: printf arguments
|
@GST_LEVEL_ERROR: Error messages are to be used only when an error occured
|
||||||
|
that stops the application from keeping working correctly.
|
||||||
|
An examples is gst_element_error, which outputs a message with this priority.
|
||||||
|
It does not mean that the application is terminating as with g_errror.
|
||||||
|
@GST_LEVEL_WARNING: Warning messages are to inform about abnormal behaviour
|
||||||
|
that could lead to problems or weird behaviour later on. An example of this
|
||||||
|
would be clocking issues ("your computer is pretty slow") or broken input
|
||||||
|
data ("Can't synchronize to stream.")
|
||||||
|
@GST_LEVEL_INFO: Informational messages should be used to keep the developer
|
||||||
|
updated about what is happening.
|
||||||
|
Examples where this should be used are when a typefind function has
|
||||||
|
successfully determined the type of the stream or when an mp3 plugin detects
|
||||||
|
the format to be used. ("This file has mono sound.")
|
||||||
|
@GST_LEVEL_DEBUG: Debugging messages should be used when something common
|
||||||
|
happens that is not the expected default behavior.
|
||||||
|
An example would be notifications about state changes or receiving/sending of
|
||||||
|
events.
|
||||||
|
@GST_LEVEL_LOG: Log messages are messages that are very common but might be
|
||||||
|
useful to know. As a rule of thumb a pipeline that is iterating as expected
|
||||||
|
should never output anzthing else but LOG messages.
|
||||||
|
Examples for this are referencing/dereferencing of objects or cothread switches.
|
||||||
|
@GST_LEVEL_COUNT: The number of defined debugging levels.
|
||||||
|
|
||||||
|
<!-- ##### MACRO GST_LEVEL_DEFAULT ##### -->
|
||||||
<!-- ##### MACRO GST_ERROR ##### -->
|
|
||||||
<para>
|
<para>
|
||||||
Print out an error condition and abort the application.
|
Defines the default debugging level to be used with GStreamer. It is
|
||||||
|
normally set to #GST_LEVEL_ERROR so only errors are printed. Developer
|
||||||
|
builds may chose to override that though.
|
||||||
|
You can use this as an argument to gst_debug_set_default_threshold() to
|
||||||
|
reset the debugging output to default behaviour.
|
||||||
</para>
|
</para>
|
||||||
|
|
||||||
@element: the #GstElement in question
|
|
||||||
@...: printf arguments
|
|
||||||
|
<!-- ##### FUNCTION gst_debug_level_get_name ##### -->
|
||||||
|
<para>
|
||||||
|
|
||||||
|
</para>
|
||||||
|
|
||||||
|
@level:
|
||||||
|
@Returns:
|
||||||
|
|
||||||
|
|
||||||
|
<!-- ##### ENUM GstDebugColorFlags ##### -->
|
||||||
|
<para>
|
||||||
|
These are some terminal-oriented flags you can use when creating your debugging
|
||||||
|
categories to make them stand out in debugging output.
|
||||||
|
</para>
|
||||||
|
|
||||||
|
@GST_DEBUG_FG_BLACK: Use black as foreground color.
|
||||||
|
@GST_DEBUG_FG_RED: Use red as foreground color.
|
||||||
|
@GST_DEBUG_FG_GREEN: Use green as foreground color.
|
||||||
|
@GST_DEBUG_FG_YELLOW: Use yellow as foreground color.
|
||||||
|
@GST_DEBUG_FG_BLUE: Use blue as foreground color.
|
||||||
|
@GST_DEBUG_FG_MAGENTA: Use magenta as foreground color.
|
||||||
|
@GST_DEBUG_FG_CYAN: Use cyan as foreground color.
|
||||||
|
@GST_DEBUG_FG_WHITE: Use white as foreground color.
|
||||||
|
@GST_DEBUG_BG_BLACK: Use black as background color.
|
||||||
|
@GST_DEBUG_BG_RED: Use red as background color.
|
||||||
|
@GST_DEBUG_BG_GREEN: Use green as background color.
|
||||||
|
@GST_DEBUG_BG_YELLOW: Use yellow as background color.
|
||||||
|
@GST_DEBUG_BG_BLUE: Use blue as background color.
|
||||||
|
@GST_DEBUG_BG_MAGENTA: Use magenta as background color.
|
||||||
|
@GST_DEBUG_BG_CYAN: Use cyan as background color.
|
||||||
|
@GST_DEBUG_BG_WHITE: Use white as background color.
|
||||||
|
@GST_DEBUG_BOLD: Make the output bold.
|
||||||
|
@GST_DEBUG_UNDERLINE: Underline the output.
|
||||||
|
|
||||||
|
<!-- ##### FUNCTION gst_debug_construct_term_color ##### -->
|
||||||
|
<para>
|
||||||
|
|
||||||
|
</para>
|
||||||
|
|
||||||
|
@colorinfo:
|
||||||
|
@Returns:
|
||||||
|
|
||||||
|
|
||||||
|
<!-- ##### STRUCT GstDebugCategory ##### -->
|
||||||
|
<para>
|
||||||
|
This is the struct that describes the categories. Once initialized with
|
||||||
|
#GST_DEBUG_CATEGORY_INIT, its values can't be changed anymore.
|
||||||
|
</para>
|
||||||
|
|
||||||
|
|
||||||
|
<!-- ##### VARIABLE GST_CAT_DEFAULT ##### -->
|
||||||
|
<para>
|
||||||
|
The default category that is used when no other category is defined as the
|
||||||
|
default. If you want to define a default category, do it like this:
|
||||||
|
<informalexample>
|
||||||
|
<programlisting>
|
||||||
|
&hash;define GST_CAT_DEFAULT category_to_be_default
|
||||||
|
</programlisting>
|
||||||
|
</informalexample>
|
||||||
|
</para>
|
||||||
|
|
||||||
|
|
||||||
|
<!-- ##### USER_FUNCTION GstLogFunction ##### -->
|
||||||
|
<para>
|
||||||
|
|
||||||
|
</para>
|
||||||
|
|
||||||
|
@category:
|
||||||
|
@level:
|
||||||
|
@file:
|
||||||
|
@function:
|
||||||
|
@line:
|
||||||
|
@object:
|
||||||
|
@message:
|
||||||
|
@data:
|
||||||
|
|
||||||
|
|
||||||
|
<!-- ##### FUNCTION gst_debug_log ##### -->
|
||||||
|
<para>
|
||||||
|
|
||||||
|
</para>
|
||||||
|
|
||||||
|
@category:
|
||||||
|
@level:
|
||||||
|
@file:
|
||||||
|
@function:
|
||||||
|
@line:
|
||||||
|
@object:
|
||||||
|
@format:
|
||||||
|
@Varargs:
|
||||||
|
|
||||||
|
|
||||||
|
<!-- ##### FUNCTION gst_debug_logv ##### -->
|
||||||
|
<para>
|
||||||
|
|
||||||
|
</para>
|
||||||
|
|
||||||
|
@category:
|
||||||
|
@level:
|
||||||
|
@file:
|
||||||
|
@function:
|
||||||
|
@line:
|
||||||
|
@object:
|
||||||
|
@format:
|
||||||
|
@args:
|
||||||
|
|
||||||
|
|
||||||
|
<!-- ##### FUNCTION gst_debug_log_default ##### -->
|
||||||
|
<para>
|
||||||
|
|
||||||
|
</para>
|
||||||
|
|
||||||
|
@category:
|
||||||
|
@level:
|
||||||
|
@file:
|
||||||
|
@function:
|
||||||
|
@line:
|
||||||
|
@object:
|
||||||
|
@message:
|
||||||
|
@unused:
|
||||||
|
|
||||||
|
|
||||||
|
<!-- ##### FUNCTION gst_debug_add_log_function ##### -->
|
||||||
|
<para>
|
||||||
|
|
||||||
|
</para>
|
||||||
|
|
||||||
|
@func:
|
||||||
|
@data:
|
||||||
|
|
||||||
|
|
||||||
|
<!-- ##### FUNCTION gst_debug_remove_log_function ##### -->
|
||||||
|
<para>
|
||||||
|
|
||||||
|
</para>
|
||||||
|
|
||||||
|
@func:
|
||||||
|
@Returns:
|
||||||
|
|
||||||
|
|
||||||
|
<!-- ##### FUNCTION gst_debug_remove_log_function_by_data ##### -->
|
||||||
|
<para>
|
||||||
|
|
||||||
|
</para>
|
||||||
|
|
||||||
|
@data:
|
||||||
|
@Returns:
|
||||||
|
|
||||||
|
|
||||||
|
<!-- ##### FUNCTION gst_debug_set_active ##### -->
|
||||||
|
<para>
|
||||||
|
|
||||||
|
</para>
|
||||||
|
|
||||||
|
@active:
|
||||||
|
|
||||||
|
|
||||||
|
<!-- ##### FUNCTION gst_debug_is_active ##### -->
|
||||||
|
<para>
|
||||||
|
|
||||||
|
</para>
|
||||||
|
|
||||||
|
@Returns:
|
||||||
|
|
||||||
|
|
||||||
|
<!-- ##### FUNCTION gst_debug_set_colored ##### -->
|
||||||
|
<para>
|
||||||
|
|
||||||
|
</para>
|
||||||
|
|
||||||
|
@colored:
|
||||||
|
|
||||||
|
|
||||||
|
<!-- ##### FUNCTION gst_debug_is_colored ##### -->
|
||||||
|
<para>
|
||||||
|
|
||||||
|
</para>
|
||||||
|
|
||||||
|
@Returns:
|
||||||
|
|
||||||
|
|
||||||
|
<!-- ##### FUNCTION gst_debug_set_default_threshold ##### -->
|
||||||
|
<para>
|
||||||
|
|
||||||
|
</para>
|
||||||
|
|
||||||
|
@level:
|
||||||
|
|
||||||
|
|
||||||
|
<!-- ##### FUNCTION gst_debug_get_default_threshold ##### -->
|
||||||
|
<para>
|
||||||
|
|
||||||
|
</para>
|
||||||
|
|
||||||
|
@Returns:
|
||||||
|
|
||||||
|
|
||||||
|
<!-- ##### FUNCTION gst_debug_set_threshold_for_name ##### -->
|
||||||
|
<para>
|
||||||
|
|
||||||
|
</para>
|
||||||
|
|
||||||
|
@name:
|
||||||
|
@level:
|
||||||
|
|
||||||
|
|
||||||
|
<!-- ##### FUNCTION gst_debug_unset_threshold_for_name ##### -->
|
||||||
|
<para>
|
||||||
|
|
||||||
|
</para>
|
||||||
|
|
||||||
|
@name:
|
||||||
|
|
||||||
|
|
||||||
|
<!-- ##### MACRO GST_DEBUG_CATEGORY ##### -->
|
||||||
|
<para>
|
||||||
|
|
||||||
|
</para>
|
||||||
|
|
||||||
|
@cat:
|
||||||
|
|
||||||
|
|
||||||
|
<!-- ##### MACRO GST_DEBUG_CATEGORY_EXTERN ##### -->
|
||||||
|
<para>
|
||||||
|
|
||||||
|
</para>
|
||||||
|
|
||||||
|
@cat:
|
||||||
|
|
||||||
|
|
||||||
|
<!-- ##### MACRO GST_DEBUG_CATEGORY_STATIC ##### -->
|
||||||
|
<para>
|
||||||
|
|
||||||
|
</para>
|
||||||
|
|
||||||
|
@cat:
|
||||||
|
|
||||||
|
|
||||||
|
<!-- ##### MACRO GST_DEBUG_CATEGORY_INIT ##### -->
|
||||||
|
<para>
|
||||||
|
|
||||||
|
</para>
|
||||||
|
|
||||||
|
@cat:
|
||||||
|
@name:
|
||||||
|
@color:
|
||||||
|
@description:
|
||||||
|
|
||||||
|
|
||||||
|
<!-- ##### FUNCTION gst_debug_category_free ##### -->
|
||||||
|
<para>
|
||||||
|
|
||||||
|
</para>
|
||||||
|
|
||||||
|
@category:
|
||||||
|
|
||||||
|
|
||||||
|
<!-- ##### FUNCTION gst_debug_category_set_threshold ##### -->
|
||||||
|
<para>
|
||||||
|
|
||||||
|
</para>
|
||||||
|
|
||||||
|
@category:
|
||||||
|
@level:
|
||||||
|
|
||||||
|
|
||||||
|
<!-- ##### FUNCTION gst_debug_category_reset_threshold ##### -->
|
||||||
|
<para>
|
||||||
|
|
||||||
|
</para>
|
||||||
|
|
||||||
|
@category:
|
||||||
|
|
||||||
|
|
||||||
|
<!-- ##### FUNCTION gst_debug_category_get_threshold ##### -->
|
||||||
|
<para>
|
||||||
|
|
||||||
|
</para>
|
||||||
|
|
||||||
|
@category:
|
||||||
|
@Returns:
|
||||||
|
|
||||||
|
|
||||||
|
<!-- ##### FUNCTION gst_debug_category_get_name ##### -->
|
||||||
|
<para>
|
||||||
|
|
||||||
|
</para>
|
||||||
|
|
||||||
|
@category:
|
||||||
|
@Returns:
|
||||||
|
|
||||||
|
|
||||||
|
<!-- ##### FUNCTION gst_debug_category_get_color ##### -->
|
||||||
|
<para>
|
||||||
|
|
||||||
|
</para>
|
||||||
|
|
||||||
|
@category:
|
||||||
|
@Returns:
|
||||||
|
|
||||||
|
|
||||||
|
<!-- ##### FUNCTION gst_debug_category_get_description ##### -->
|
||||||
|
<para>
|
||||||
|
|
||||||
|
</para>
|
||||||
|
|
||||||
|
@category:
|
||||||
|
@Returns:
|
||||||
|
|
||||||
|
|
||||||
|
<!-- ##### FUNCTION gst_debug_get_all_categories ##### -->
|
||||||
|
<para>
|
||||||
|
|
||||||
|
</para>
|
||||||
|
|
||||||
|
@Returns:
|
||||||
|
|
||||||
|
|
||||||
|
<!-- ##### MACRO GST_CAT_LEVEL_LOG ##### -->
|
||||||
|
<para>
|
||||||
|
|
||||||
|
</para>
|
||||||
|
|
||||||
|
@cat:
|
||||||
|
@level:
|
||||||
|
@object:
|
||||||
|
@...:
|
||||||
|
|
||||||
|
|
||||||
|
<!-- ##### MACRO GST_CAT_ERROR_OBJECT ##### -->
|
||||||
|
<para>
|
||||||
|
Output an error message belonging to the given object in the given category.
|
||||||
|
</para>
|
||||||
|
|
||||||
|
@cat: category to use
|
||||||
|
@obj: the #GObject the message belongs to
|
||||||
|
@...: printf-style message to output
|
||||||
|
|
||||||
|
|
||||||
|
<!-- ##### MACRO GST_CAT_WARNING_OBJECT ##### -->
|
||||||
|
<para>
|
||||||
|
Output a warning message belonging to the given object in the given category.
|
||||||
|
</para>
|
||||||
|
|
||||||
|
@cat: category to use
|
||||||
|
@obj: the #GObject the message belongs to
|
||||||
|
@...: printf-style message to output
|
||||||
|
|
||||||
|
|
||||||
|
<!-- ##### MACRO GST_CAT_INFO_OBJECT ##### -->
|
||||||
|
<para>
|
||||||
|
Output an informational message belonging to the given object in the given
|
||||||
|
category.
|
||||||
|
</para>
|
||||||
|
|
||||||
|
@cat: category to use
|
||||||
|
@obj: the #GObject the message belongs to
|
||||||
|
@...: printf-style message to output
|
||||||
|
|
||||||
|
|
||||||
|
<!-- ##### MACRO GST_CAT_DEBUG_OBJECT ##### -->
|
||||||
|
<para>
|
||||||
|
Output an debugging message belonging to the given object in the given category.
|
||||||
|
</para>
|
||||||
|
|
||||||
|
@cat: category to use
|
||||||
|
@obj: the #GObject the message belongs to
|
||||||
|
@...: printf-style message to output
|
||||||
|
|
||||||
|
|
||||||
|
<!-- ##### MACRO GST_CAT_LOG_OBJECT ##### -->
|
||||||
|
<para>
|
||||||
|
Output an logging message belonging to the given object in the given category.
|
||||||
|
</para>
|
||||||
|
|
||||||
|
@cat: category to use
|
||||||
|
@obj: the #GObject the message belongs to
|
||||||
|
@...: printf-style message to output
|
||||||
|
|
||||||
|
|
||||||
|
<!-- ##### MACRO GST_CAT_ERROR ##### -->
|
||||||
|
<para>
|
||||||
|
Output an error message in the given category.
|
||||||
|
</para>
|
||||||
|
|
||||||
|
@cat: category to use
|
||||||
|
@...: printf-style message to output
|
||||||
|
|
||||||
|
|
||||||
|
<!-- ##### MACRO GST_CAT_WARNING ##### -->
|
||||||
|
<para>
|
||||||
|
Output a warning message in the given category.
|
||||||
|
</para>
|
||||||
|
|
||||||
|
@cat: category to use
|
||||||
|
@...: printf-style message to output
|
||||||
|
|
||||||
|
|
||||||
|
<!-- ##### MACRO GST_CAT_INFO ##### -->
|
||||||
|
<para>
|
||||||
|
Output an informational message in the given category.
|
||||||
|
</para>
|
||||||
|
|
||||||
|
@cat: category to use
|
||||||
|
@...: printf-style message to output
|
||||||
|
|
||||||
|
|
||||||
|
<!-- ##### MACRO GST_CAT_DEBUG ##### -->
|
||||||
|
<para>
|
||||||
|
Output a debuggign message in the given category.
|
||||||
|
</para>
|
||||||
|
|
||||||
|
@cat: category to use
|
||||||
|
@...: printf-style message to output
|
||||||
|
|
||||||
|
|
||||||
|
<!-- ##### MACRO GST_CAT_LOG ##### -->
|
||||||
|
<para>
|
||||||
|
Output a logging message in the given category.
|
||||||
|
</para>
|
||||||
|
|
||||||
|
@cat: category to use
|
||||||
|
@...: printf-style message to output
|
||||||
|
|
||||||
|
|
||||||
<!-- ##### MACRO GST_ERROR_OBJECT ##### -->
|
<!-- ##### MACRO GST_ERROR_OBJECT ##### -->
|
||||||
<para>
|
<para>
|
||||||
Print out an error condition and abort the application.
|
Output an error message belonging to the given object in the default category.
|
||||||
</para>
|
</para>
|
||||||
|
|
||||||
@element: the #GstElement in question
|
@obj: the #GObject the message belongs to
|
||||||
@object: pointer to a 'contributing' object
|
@...: printf-style message to output
|
||||||
@...: printf arguments
|
|
||||||
|
|
||||||
|
|
||||||
<!-- ##### USER_FUNCTION GstDebugHandler ##### -->
|
<!-- ##### MACRO GST_WARNING_OBJECT ##### -->
|
||||||
<para>
|
<para>
|
||||||
The debug handler
|
Output a warning message belonging to the given object in the default category.
|
||||||
</para>
|
</para>
|
||||||
|
|
||||||
@category:
|
@obj: the #GObject the message belongs to
|
||||||
@core:
|
@...: printf-style message to output
|
||||||
@file:
|
|
||||||
@function:
|
|
||||||
@line:
|
|
||||||
@debug_string:
|
|
||||||
@element:
|
|
||||||
@string:
|
|
||||||
|
|
||||||
|
|
||||||
<!-- ##### FUNCTION gst_default_debug_handler ##### -->
|
<!-- ##### MACRO GST_INFO_OBJECT ##### -->
|
||||||
|
<para>
|
||||||
|
Output an informational message belonging to the given object in the default
|
||||||
|
category.
|
||||||
|
</para>
|
||||||
|
|
||||||
|
@obj: the #GObject the message belongs to
|
||||||
|
@...: printf-style message to output
|
||||||
|
|
||||||
|
|
||||||
|
<!-- ##### MACRO GST_DEBUG_OBJECT ##### -->
|
||||||
|
<para>
|
||||||
|
Output a debugging message belonging to the given object in the default
|
||||||
|
category.
|
||||||
|
</para>
|
||||||
|
|
||||||
|
@obj: the #GObject the message belongs to
|
||||||
|
@...: printf-style message to output
|
||||||
|
|
||||||
|
|
||||||
|
<!-- ##### MACRO GST_LOG_OBJECT ##### -->
|
||||||
|
<para>
|
||||||
|
Output a logging message belonging to the given object in the default category.
|
||||||
|
</para>
|
||||||
|
|
||||||
|
@obj: the #GObject the message belongs to
|
||||||
|
@...: printf-style message to output
|
||||||
|
|
||||||
|
|
||||||
|
<!-- ##### MACRO GST_ERROR ##### -->
|
||||||
|
<para>
|
||||||
|
Output an error message in the default category.
|
||||||
|
</para>
|
||||||
|
|
||||||
|
@...: printf-style message to output
|
||||||
|
|
||||||
|
|
||||||
|
<!-- ##### MACRO GST_WARNING ##### -->
|
||||||
|
<para>
|
||||||
|
Output a warning message in the default category.
|
||||||
|
</para>
|
||||||
|
|
||||||
|
@...: printf-style message to output
|
||||||
|
|
||||||
|
|
||||||
|
<!-- ##### MACRO GST_INFO ##### -->
|
||||||
|
<para>
|
||||||
|
Output an informational message in the default category.
|
||||||
|
</para>
|
||||||
|
|
||||||
|
@...: printf-style message to output
|
||||||
|
|
||||||
|
|
||||||
|
<!-- ##### MACRO GST_DEBUG ##### -->
|
||||||
|
<para>
|
||||||
|
Output a debugging message in the default category.
|
||||||
|
</para>
|
||||||
|
|
||||||
|
@...: printf-style message to output
|
||||||
|
|
||||||
|
|
||||||
|
<!-- ##### MACRO GST_LOG ##### -->
|
||||||
|
<para>
|
||||||
|
Output a logging message in the default category.
|
||||||
|
</para>
|
||||||
|
|
||||||
|
@...: printf-style message to output
|
||||||
|
|
||||||
|
|
||||||
|
<!-- ##### MACRO GST_DEBUG_FUNCPTR ##### -->
|
||||||
<para>
|
<para>
|
||||||
|
|
||||||
</para>
|
</para>
|
||||||
|
|
||||||
@category:
|
@ptr:
|
||||||
@incore:
|
|
||||||
@file:
|
|
||||||
@function:
|
|
||||||
@line:
|
|
||||||
@debug_string:
|
|
||||||
@element:
|
|
||||||
@string:
|
|
||||||
|
|
||||||
|
|
||||||
<!-- ##### FUNCTION gst_default_error_handler ##### -->
|
<!-- ##### MACRO GST_DEBUG_FUNCPTR_NAME ##### -->
|
||||||
<para>
|
<para>
|
||||||
|
|
||||||
</para>
|
</para>
|
||||||
|
|
||||||
@file:
|
@ptr:
|
||||||
@function:
|
|
||||||
@line:
|
|
||||||
@debug_string:
|
|
||||||
@element:
|
|
||||||
@object:
|
|
||||||
@string:
|
|
||||||
|
|
||||||
|
|
||||||
<!-- ##### USER_FUNCTION GstInfoHandler ##### -->
|
|
||||||
<para>
|
|
||||||
The info handler
|
|
||||||
</para>
|
|
||||||
|
|
||||||
@category:
|
|
||||||
@incore:
|
|
||||||
@file:
|
|
||||||
@function:
|
|
||||||
@line:
|
|
||||||
@debug_string:
|
|
||||||
@element:
|
|
||||||
@string:
|
|
||||||
|
|
||||||
|
|
||||||
<!-- ##### USER_FUNCTION GstErrorHandler ##### -->
|
|
||||||
<para>
|
|
||||||
The error handler
|
|
||||||
</para>
|
|
||||||
|
|
||||||
@file:
|
|
||||||
@function:
|
|
||||||
@line:
|
|
||||||
@debug_string:
|
|
||||||
@element:
|
|
||||||
@object:
|
|
||||||
@string:
|
|
||||||
|
|
||||||
|
|
||||||
|
|
|
@ -185,8 +185,10 @@ maintainer-clean-local: clean
|
||||||
# make distcheck work
|
# make distcheck work
|
||||||
distclean-local: clean
|
distclean-local: clean
|
||||||
rm -rf $(DOC_MODULE)-decl-list.txt
|
rm -rf $(DOC_MODULE)-decl-list.txt
|
||||||
rm -rf $(DOC_MODULE)-*.txt
|
rm -rf $(DOC_MODULE)-decl.txt
|
||||||
rm -rf tmpl/*.sgml
|
rm -rf $(DOC_MODULE)-undocumented.txt
|
||||||
|
rm -rf $(DOC_MODULE)-unused.txt
|
||||||
|
rm -rf tmpl/*.sgml.bak
|
||||||
rm -f $(DOC_MODULE).hierarchy
|
rm -f $(DOC_MODULE).hierarchy
|
||||||
rm -f *.stamp || true
|
rm -f *.stamp || true
|
||||||
|
|
||||||
|
|
|
@ -1,10 +1,9 @@
|
||||||
<?xml version="1.0"?>
|
<?xml version="1.0"?>
|
||||||
<!DOCTYPE book PUBLIC "-//OASIS//DTD DocBook XML V4.1.2//EN"
|
<!DOCTYPE book PUBLIC "-//OASIS//DTD DocBook XML V4.1.2//EN"
|
||||||
"http://www.oasis-open.org/docbook/xml/4.1.2/docbookx.dtd" [
|
"http://www.oasis-open.org/docbook/xml/4.1.2/docbookx.dtd" [
|
||||||
<!ENTITY GstGetbits SYSTEM "xml/gstgetbits.xml">
|
<!ENTITY GstGetbits SYSTEM "xml/getbits.xml">
|
||||||
<!ENTITY GstIDCT SYSTEM "xml/gstidct.xml">
|
<!ENTITY GstPutbits SYSTEM "xml/putbits.xml">
|
||||||
<!ENTITY GstPutbits SYSTEM "xml/gstputbits.xml">
|
<!ENTITY GstControl SYSTEM "xml/control.xml">
|
||||||
<!ENTITY GstControl SYSTEM "xml/gstcontrol.xml">
|
|
||||||
|
|
||||||
]>
|
]>
|
||||||
|
|
||||||
|
@ -24,7 +23,6 @@
|
||||||
GStreamer provides some standard libraries you can use to create plugins.
|
GStreamer provides some standard libraries you can use to create plugins.
|
||||||
</para>
|
</para>
|
||||||
&GstGetbits;
|
&GstGetbits;
|
||||||
&GstIDCT;
|
|
||||||
&GstPutbits;
|
&GstPutbits;
|
||||||
&GstControl;
|
&GstControl;
|
||||||
|
|
||||||
|
|
|
@ -10,6 +10,7 @@
|
||||||
<!ENTITY INTRO_BASICS SYSTEM "intro_basics.xml">
|
<!ENTITY INTRO_BASICS SYSTEM "intro_basics.xml">
|
||||||
|
|
||||||
<!ENTITY BUILDING_BOILER SYSTEM "building_boiler.xml">
|
<!ENTITY BUILDING_BOILER SYSTEM "building_boiler.xml">
|
||||||
|
<!ENTITY BUILDING_DEBUG SYSTEM "building_debug.xml">
|
||||||
<!ENTITY BUILDING_PADS SYSTEM "building_pads.xml">
|
<!ENTITY BUILDING_PADS SYSTEM "building_pads.xml">
|
||||||
<!ENTITY BUILDING_CHAINFN SYSTEM "building_chainfn.xml">
|
<!ENTITY BUILDING_CHAINFN SYSTEM "building_chainfn.xml">
|
||||||
<!ENTITY BUILDING_STATE SYSTEM "building_state.xml">
|
<!ENTITY BUILDING_STATE SYSTEM "building_state.xml">
|
||||||
|
|
|
@ -10,7 +10,7 @@ gst_play_have_type (GstElement *typefind, GstCaps *caps, GstElement *pipeline)
|
||||||
GstElement *filesrc;
|
GstElement *filesrc;
|
||||||
GstElement *cache;
|
GstElement *cache;
|
||||||
|
|
||||||
GST_DEBUG (0,"GstPipeline: play have type");
|
GST_DEBUG ("GstPipeline: play have type");
|
||||||
|
|
||||||
gst_element_set_state (pipeline, GST_STATE_PAUSED);
|
gst_element_set_state (pipeline, GST_STATE_PAUSED);
|
||||||
|
|
||||||
|
|
|
@ -10,7 +10,7 @@ gst_play_have_type (GstElement *typefind, GstCaps *caps, GstElement *pipeline)
|
||||||
GstElement *filesrc;
|
GstElement *filesrc;
|
||||||
GstElement *cache;
|
GstElement *cache;
|
||||||
|
|
||||||
GST_DEBUG (0,"GstPipeline: play have type");
|
GST_DEBUG ("GstPipeline: play have type");
|
||||||
|
|
||||||
gst_element_set_state (pipeline, GST_STATE_PAUSED);
|
gst_element_set_state (pipeline, GST_STATE_PAUSED);
|
||||||
|
|
||||||
|
|
|
@ -47,7 +47,7 @@ gst_play_type_find (GstBin *bin, GstElement *element)
|
||||||
GstElement *pipeline;
|
GstElement *pipeline;
|
||||||
GstCaps *caps = NULL;
|
GstCaps *caps = NULL;
|
||||||
|
|
||||||
GST_DEBUG (0,"GstPipeline: typefind for element \"%s\"",
|
GST_DEBUG ("GstPipeline: typefind for element \"%s\"",
|
||||||
GST_ELEMENT_NAME(element));
|
GST_ELEMENT_NAME(element));
|
||||||
|
|
||||||
pipeline = gst_pipeline_new ("autoplug_pipeline");
|
pipeline = gst_pipeline_new ("autoplug_pipeline");
|
||||||
|
@ -116,9 +116,9 @@ int main(int argc,char *argv[])
|
||||||
main_bin = gst_pipeline_new("bin");
|
main_bin = gst_pipeline_new("bin");
|
||||||
|
|
||||||
/* link adder and output to bin */
|
/* link adder and output to bin */
|
||||||
GST_INFO (0, "main: adding adder to bin");
|
GST_INFO ( "main: adding adder to bin");
|
||||||
gst_bin_add (GST_BIN(main_bin), adder);
|
gst_bin_add (GST_BIN(main_bin), adder);
|
||||||
GST_INFO (0, "main: adding audiosink to bin");
|
GST_INFO ( "main: adding audiosink to bin");
|
||||||
gst_bin_add (GST_BIN(main_bin), audiosink);
|
gst_bin_add (GST_BIN(main_bin), audiosink);
|
||||||
|
|
||||||
/* link adder and audiosink */
|
/* link adder and audiosink */
|
||||||
|
@ -139,7 +139,7 @@ int main(int argc,char *argv[])
|
||||||
gst_bin_add (GST_BIN(main_bin), channel_in->pipe);
|
gst_bin_add (GST_BIN(main_bin), channel_in->pipe);
|
||||||
|
|
||||||
/* request pads and link to adder */
|
/* request pads and link to adder */
|
||||||
GST_INFO (0, "requesting pad\n");
|
GST_INFO ( "requesting pad\n");
|
||||||
pad = gst_element_get_request_pad (adder, "sink%d");
|
pad = gst_element_get_request_pad (adder, "sink%d");
|
||||||
printf ("\tGot new adder sink pad %s\n", gst_pad_get_name (pad));
|
printf ("\tGot new adder sink pad %s\n", gst_pad_get_name (pad));
|
||||||
sprintf (buffer, "channel%d", i);
|
sprintf (buffer, "channel%d", i);
|
||||||
|
@ -242,7 +242,7 @@ create_input_channel (int id, char* location)
|
||||||
GstElement *new_element;
|
GstElement *new_element;
|
||||||
GstElement *decoder;
|
GstElement *decoder;
|
||||||
|
|
||||||
GST_DEBUG (0, "c_i_p : creating channel with id %d for file %s",
|
GST_DEBUG ( "c_i_p : creating channel with id %d for file %s",
|
||||||
id, location);
|
id, location);
|
||||||
|
|
||||||
/* allocate channel */
|
/* allocate channel */
|
||||||
|
@ -256,7 +256,7 @@ create_input_channel (int id, char* location)
|
||||||
|
|
||||||
/* create channel */
|
/* create channel */
|
||||||
|
|
||||||
GST_DEBUG (0, "c_i_p : creating pipeline");
|
GST_DEBUG ( "c_i_p : creating pipeline");
|
||||||
|
|
||||||
sprintf (buffer, "pipeline%d", id);
|
sprintf (buffer, "pipeline%d", id);
|
||||||
channel->pipe = gst_bin_new (buffer);
|
channel->pipe = gst_bin_new (buffer);
|
||||||
|
@ -264,13 +264,13 @@ create_input_channel (int id, char* location)
|
||||||
|
|
||||||
/* create elements */
|
/* create elements */
|
||||||
|
|
||||||
GST_DEBUG(0, "c_i_p : creating filesrc");
|
GST_DEBUG ( "c_i_p : creating filesrc");
|
||||||
|
|
||||||
sprintf (buffer, "filesrc%d", id);
|
sprintf (buffer, "filesrc%d", id);
|
||||||
channel->filesrc = gst_element_factory_make ("filesrc", buffer);
|
channel->filesrc = gst_element_factory_make ("filesrc", buffer);
|
||||||
g_assert(channel->filesrc != NULL);
|
g_assert(channel->filesrc != NULL);
|
||||||
|
|
||||||
GST_DEBUG(0, "c_i_p : setting location");
|
GST_DEBUG ( "c_i_p : setting location");
|
||||||
g_object_set(G_OBJECT(channel->filesrc),"location", location, NULL);
|
g_object_set(G_OBJECT(channel->filesrc),"location", location, NULL);
|
||||||
|
|
||||||
/* add filesrc to the bin before autoplug */
|
/* add filesrc to the bin before autoplug */
|
||||||
|
|
|
@ -30,7 +30,7 @@ static GstElementDetails example_details = {
|
||||||
"An example plugin",
|
"An example plugin",
|
||||||
"Example/FirstExample",
|
"Example/FirstExample",
|
||||||
"Shows the basic structure of a plugin",
|
"Shows the basic structure of a plugin",
|
||||||
VERSION,
|
"0.1",
|
||||||
"your name <your.name@your.isp>",
|
"your name <your.name@your.isp>",
|
||||||
"(C) 2001",
|
"(C) 2001",
|
||||||
};
|
};
|
||||||
|
|
|
@ -134,7 +134,7 @@ libgstreamer_@GST_MAJORMINOR@_la_SOURCES = \
|
||||||
$(GST_LOADSAVE_SRC)
|
$(GST_LOADSAVE_SRC)
|
||||||
|
|
||||||
|
|
||||||
BUILT_SOURCES = gstmarshal.h gstmarshal.c gstenumtypes.h $(GST_ENUMTYPES_SRC)
|
BUILT_SOURCES = gstversion.h gstconfig.h gstmarshal.h gstmarshal.c gstenumtypes.h $(GST_ENUMTYPES_SRC)
|
||||||
|
|
||||||
libgstreamer_@GST_MAJORMINOR@_la_CFLAGS = -D_GNU_SOURCE \
|
libgstreamer_@GST_MAJORMINOR@_la_CFLAGS = -D_GNU_SOURCE \
|
||||||
$(GST_CFLAGS) \
|
$(GST_CFLAGS) \
|
||||||
|
@ -150,7 +150,6 @@ libgstreamer_@GST_MAJORMINOR@includedir = $(includedir)/gstreamer-@GST_MAJORMINO
|
||||||
gst_headers = \
|
gst_headers = \
|
||||||
gst.h \
|
gst.h \
|
||||||
gstatomic.h \
|
gstatomic.h \
|
||||||
gstconfig.h \
|
|
||||||
gstobject.h \
|
gstobject.h \
|
||||||
gsttypes.h \
|
gsttypes.h \
|
||||||
gstautoplug.h \
|
gstautoplug.h \
|
||||||
|
@ -195,6 +194,7 @@ gst_headers = \
|
||||||
gstxml.h
|
gstxml.h
|
||||||
|
|
||||||
built_headers = \
|
built_headers = \
|
||||||
|
gstconfig.h \
|
||||||
gstversion.h \
|
gstversion.h \
|
||||||
gstmarshal.h \
|
gstmarshal.h \
|
||||||
gstenumtypes.h
|
gstenumtypes.h
|
||||||
|
|
|
@ -19,8 +19,15 @@
|
||||||
* Boston, MA 02111-1307, USA.
|
* Boston, MA 02111-1307, USA.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
#ifdef HAVE_CONFIG_H
|
||||||
|
# include "config.h"
|
||||||
|
#endif
|
||||||
|
|
||||||
#include <gst/gst.h>
|
#include <gst/gst.h>
|
||||||
|
|
||||||
|
GST_DEBUG_CATEGORY_STATIC(debug_category);
|
||||||
|
#define GST_CAT_DEFAULT debug_category
|
||||||
|
|
||||||
GstElementDetails gst_autoplugcache_details = {
|
GstElementDetails gst_autoplugcache_details = {
|
||||||
"AutoplugCache",
|
"AutoplugCache",
|
||||||
"Generic",
|
"Generic",
|
||||||
|
@ -230,12 +237,12 @@ gst_autoplugcache_loop (GstElement *element)
|
||||||
/* if we've been told to fire an empty signal (after a reset) */
|
/* if we've been told to fire an empty signal (after a reset) */
|
||||||
if (cache->fire_empty) {
|
if (cache->fire_empty) {
|
||||||
int oldstate = GST_STATE(cache);
|
int oldstate = GST_STATE(cache);
|
||||||
GST_DEBUG(0,"at front of cache, about to pull, but firing signal");
|
GST_DEBUG ("at front of cache, about to pull, but firing signal");
|
||||||
gst_object_ref (GST_OBJECT (cache));
|
gst_object_ref (GST_OBJECT (cache));
|
||||||
g_signal_emit (G_OBJECT(cache), gst_autoplugcache_signals[CACHE_EMPTY], 0, NULL);
|
g_signal_emit (G_OBJECT(cache), gst_autoplugcache_signals[CACHE_EMPTY], 0, NULL);
|
||||||
if (GST_STATE(cache) != oldstate) {
|
if (GST_STATE(cache) != oldstate) {
|
||||||
gst_object_unref (GST_OBJECT (cache));
|
gst_object_unref (GST_OBJECT (cache));
|
||||||
GST_DEBUG(GST_CAT_AUTOPLUG, "state changed during signal, aborting");
|
GST_DEBUG ("state changed during signal, aborting");
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
gst_object_unref (GST_OBJECT (cache));
|
gst_object_unref (GST_OBJECT (cache));
|
||||||
|
@ -295,7 +302,7 @@ gst_autoplugcache_set_property (GObject *object, guint prop_id, const GValue *va
|
||||||
switch (prop_id) {
|
switch (prop_id) {
|
||||||
case ARG_CAPS_PROXY:
|
case ARG_CAPS_PROXY:
|
||||||
cache->caps_proxy = g_value_get_boolean (value);
|
cache->caps_proxy = g_value_get_boolean (value);
|
||||||
GST_DEBUG(0,"caps_proxy is %d",cache->caps_proxy);
|
GST_DEBUG ("caps_proxy is %d",cache->caps_proxy);
|
||||||
if (cache->caps_proxy) {
|
if (cache->caps_proxy) {
|
||||||
} else {
|
} else {
|
||||||
}
|
}
|
||||||
|
@ -303,7 +310,7 @@ GST_DEBUG(0,"caps_proxy is %d",cache->caps_proxy);
|
||||||
case ARG_RESET:
|
case ARG_RESET:
|
||||||
/* no idea why anyone would set this to FALSE, but just in case ;-) */
|
/* no idea why anyone would set this to FALSE, but just in case ;-) */
|
||||||
if (g_value_get_boolean (value)) {
|
if (g_value_get_boolean (value)) {
|
||||||
GST_DEBUG(0,"resetting playout pointer");
|
GST_DEBUG ("resetting playout pointer");
|
||||||
/* reset the playout pointer to the begining again */
|
/* reset the playout pointer to the begining again */
|
||||||
cache->current_playout = cache->cache_start;
|
cache->current_playout = cache->cache_start;
|
||||||
/* now we can fire a signal when the cache runs dry */
|
/* now we can fire a signal when the cache runs dry */
|
||||||
|
@ -342,6 +349,8 @@ plugin_init (GModule *module, GstPlugin *plugin)
|
||||||
{
|
{
|
||||||
GstElementFactory *factory;
|
GstElementFactory *factory;
|
||||||
|
|
||||||
|
GST_DEBUG_CATEGORY_INIT (debug_category, "AUTOPLUGCACHE", 0, "autoplugcache element");
|
||||||
|
|
||||||
factory = gst_element_factory_new ("autoplugcache", GST_TYPE_AUTOPLUGCACHE,
|
factory = gst_element_factory_new ("autoplugcache", GST_TYPE_AUTOPLUGCACHE,
|
||||||
&gst_autoplugcache_details);
|
&gst_autoplugcache_details);
|
||||||
g_return_val_if_fail (factory != NULL, FALSE);
|
g_return_val_if_fail (factory != NULL, FALSE);
|
||||||
|
@ -357,4 +366,3 @@ GstPluginDesc plugin_desc = {
|
||||||
"autoplugcache",
|
"autoplugcache",
|
||||||
plugin_init
|
plugin_init
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
|
@ -19,6 +19,10 @@
|
||||||
* Boston, MA 02111-1307, USA.
|
* Boston, MA 02111-1307, USA.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
#ifdef HAVE_CONFIG_H
|
||||||
|
# include "config.h"
|
||||||
|
#endif
|
||||||
|
|
||||||
#include <gst/gst.h>
|
#include <gst/gst.h>
|
||||||
|
|
||||||
GstElementDetails gst_autoplugger_details = {
|
GstElementDetails gst_autoplugger_details = {
|
||||||
|
@ -171,7 +175,7 @@ gst_autoplugger_init (GstAutoplugger *autoplugger)
|
||||||
autoplugger->cache = gst_element_factory_make("autoplugcache", "unnamed_autoplugcache");
|
autoplugger->cache = gst_element_factory_make("autoplugcache", "unnamed_autoplugcache");
|
||||||
g_return_if_fail (autoplugger->cache != NULL);
|
g_return_if_fail (autoplugger->cache != NULL);
|
||||||
|
|
||||||
GST_DEBUG(GST_CAT_AUTOPLUG, "turning on caps nego proxying in cache");
|
GST_DEBUG ("turning on caps nego proxying in cache");
|
||||||
g_object_set(G_OBJECT(autoplugger->cache),"caps_proxy",TRUE,NULL);
|
g_object_set(G_OBJECT(autoplugger->cache),"caps_proxy",TRUE,NULL);
|
||||||
|
|
||||||
/* attach signals to the cache */
|
/* attach signals to the cache */
|
||||||
|
@ -213,19 +217,19 @@ gst_autoplugger_external_sink_linked(GstPad *pad, GstPad *peerpad, GstAutoplugge
|
||||||
GstPadTemplate *peertemplate;
|
GstPadTemplate *peertemplate;
|
||||||
GstCaps *peercaps, *peertemplatecaps;
|
GstCaps *peercaps, *peertemplatecaps;
|
||||||
|
|
||||||
GST_INFO(GST_CAT_AUTOPLUG, "have cache:sink linked");*/
|
GST_INFO ("have cache:sink linked");*/
|
||||||
/* autoplugger->sinkpadpeer = peerpad; */
|
/* autoplugger->sinkpadpeer = peerpad; */
|
||||||
/*
|
/*
|
||||||
if (autoplugger->sinkpadpeer) {
|
if (autoplugger->sinkpadpeer) {
|
||||||
peercaps = GST_PAD_CAPS(autoplugger->sinkpadpeer);
|
peercaps = GST_PAD_CAPS(autoplugger->sinkpadpeer);
|
||||||
if (peercaps)
|
if (peercaps)
|
||||||
GST_INFO(GST_CAT_AUTOPLUG, "there are some caps on this pad's peer: %s",
|
GST_INFO ("there are some caps on this pad's peer: %s",
|
||||||
gst_caps_get_mime(peercaps));
|
gst_caps_get_mime(peercaps));
|
||||||
peertemplate = GST_PAD_PAD_TEMPLATE(autoplugger->sinkpadpeer);
|
peertemplate = GST_PAD_PAD_TEMPLATE(autoplugger->sinkpadpeer);
|
||||||
if (peertemplate) {
|
if (peertemplate) {
|
||||||
peertemplatecaps = GST_PAD_TEMPLATE_CAPS(peertemplate);
|
peertemplatecaps = GST_PAD_TEMPLATE_CAPS(peertemplate);
|
||||||
if (peertemplatecaps) {
|
if (peertemplatecaps) {
|
||||||
GST_INFO(GST_CAT_AUTOPLUG, "there are some caps on this pad's peer's padtemplate %s",
|
GST_INFO ("there are some caps on this pad's peer's padtemplate %s",
|
||||||
gst_caps_get_mime(peertemplatecaps));
|
gst_caps_get_mime(peertemplatecaps));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -238,22 +242,22 @@ gst_autoplugger_external_src_linked(GstPad *pad, GstPad *peerpad, GstAutoplugger
|
||||||
GstPadTemplate *peertemplate;
|
GstPadTemplate *peertemplate;
|
||||||
GstCaps *peercaps, *peertemplatecaps;
|
GstCaps *peercaps, *peertemplatecaps;
|
||||||
|
|
||||||
GST_INFO(GST_CAT_AUTOPLUG, "have cache:src linked");*/
|
GST_INFO ("have cache:src linked");*/
|
||||||
/* autoplugger->srcpadpeer = peerpad; */
|
/* autoplugger->srcpadpeer = peerpad; */
|
||||||
/*
|
/*
|
||||||
if (autoplugger->srcpadpeer) {
|
if (autoplugger->srcpadpeer) {
|
||||||
peercaps = GST_PAD_CAPS(autoplugger->srcpadpeer);
|
peercaps = GST_PAD_CAPS(autoplugger->srcpadpeer);
|
||||||
if (peercaps)
|
if (peercaps)
|
||||||
GST_INFO(GST_CAT_AUTOPLUG, "there are some caps on this pad's peer: %s",
|
GST_INFO ("there are some caps on this pad's peer: %s",
|
||||||
gst_caps_get_mime(peercaps));
|
gst_caps_get_mime(peercaps));
|
||||||
peertemplate = GST_PAD_PAD_TEMPLATE(autoplugger->srcpadpeer);
|
peertemplate = GST_PAD_PAD_TEMPLATE(autoplugger->srcpadpeer);
|
||||||
if (peertemplate) {
|
if (peertemplate) {
|
||||||
peertemplatecaps = GST_PAD_TEMPLATE_CAPS(peertemplate);
|
peertemplatecaps = GST_PAD_TEMPLATE_CAPS(peertemplate);
|
||||||
if (peertemplatecaps) {
|
if (peertemplatecaps) {
|
||||||
GST_INFO(GST_CAT_AUTOPLUG, "there are some caps on this pad's peer's padtemplate %s",
|
GST_INFO ("there are some caps on this pad's peer's padtemplate %s",
|
||||||
gst_caps_get_mime(peertemplatecaps));
|
gst_caps_get_mime(peertemplatecaps));
|
||||||
autoplugger->sinktemplatecaps = peertemplatecaps;*/
|
autoplugger->sinktemplatecaps = peertemplatecaps;*/
|
||||||
/* GST_DEBUG(GST_CAT_AUTOPLUG, "turning on caps nego proxying in cache"); */
|
/* GST_DEBUG ("turning on caps nego proxying in cache"); */
|
||||||
/* gtk_object_set(G_OBJECT(autoplugger->cache),"caps_proxy",TRUE,NULL);*/
|
/* gtk_object_set(G_OBJECT(autoplugger->cache),"caps_proxy",TRUE,NULL);*/
|
||||||
/* }
|
/* }
|
||||||
}
|
}
|
||||||
|
@ -265,14 +269,14 @@ gst_autoplugger_external_src_linked(GstPad *pad, GstPad *peerpad, GstAutoplugger
|
||||||
static void
|
static void
|
||||||
gst_autoplugger_external_sink_caps_changed(GstPad *pad, GstCaps *caps, GstAutoplugger *autoplugger)
|
gst_autoplugger_external_sink_caps_changed(GstPad *pad, GstCaps *caps, GstAutoplugger *autoplugger)
|
||||||
{
|
{
|
||||||
GST_INFO(GST_CAT_AUTOPLUG, "have cache:sink caps of %s\n",gst_caps_get_mime(caps));
|
GST_INFO ("have cache:sink caps of %s\n",gst_caps_get_mime(caps));
|
||||||
autoplugger->sinkcaps = caps;
|
autoplugger->sinkcaps = caps;
|
||||||
}
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
gst_autoplugger_external_src_caps_changed(GstPad *pad, GstCaps *caps, GstAutoplugger *autoplugger)
|
gst_autoplugger_external_src_caps_changed(GstPad *pad, GstCaps *caps, GstAutoplugger *autoplugger)
|
||||||
{
|
{
|
||||||
GST_INFO(GST_CAT_AUTOPLUG, "have cache:src caps of %s\n",gst_caps_get_mime(caps));
|
GST_INFO ("have cache:src caps of %s\n",gst_caps_get_mime(caps));
|
||||||
autoplugger->srccaps = caps;
|
autoplugger->srccaps = caps;
|
||||||
}
|
}
|
||||||
*/
|
*/
|
||||||
|
@ -284,20 +288,20 @@ gst_autoplugger_autoplug(GstAutoplugger *autoplugger,GstPad *srcpad,GstCaps *src
|
||||||
GstPad *sinkpad;
|
GstPad *sinkpad;
|
||||||
|
|
||||||
sinkpad = GST_PAD(GST_PAD_PEER(srcpad));
|
sinkpad = GST_PAD(GST_PAD_PEER(srcpad));
|
||||||
GST_DEBUG(GST_CAT_AUTOPLUG,"unlinking %s:%s and %s:%s to autoplug between them",
|
GST_DEBUG ("unlinking %s:%s and %s:%s to autoplug between them",
|
||||||
GST_DEBUG_PAD_NAME(srcpad),GST_DEBUG_PAD_NAME(sinkpad));
|
GST_DEBUG_PAD_NAME(srcpad),GST_DEBUG_PAD_NAME(sinkpad));
|
||||||
GST_DEBUG(GST_CAT_AUTOPLUG,"srcpadcaps are of type %s",gst_caps_get_mime(srccaps));
|
GST_DEBUG ("srcpadcaps are of type %s",gst_caps_get_mime(srccaps));
|
||||||
GST_DEBUG(GST_CAT_AUTOPLUG,"sinkpadcaps are of type %s",gst_caps_get_mime(sinkcaps));
|
GST_DEBUG ("sinkpadcaps are of type %s",gst_caps_get_mime(sinkcaps));
|
||||||
|
|
||||||
/* unlink the pads */
|
/* unlink the pads */
|
||||||
GST_DEBUG(GST_CAT_AUTOPLUG, "unlinking the pads that will be joined by an autobin");
|
GST_DEBUG ("unlinking the pads that will be joined by an autobin");
|
||||||
gst_pad_unlink(srcpad,sinkpad);
|
gst_pad_unlink(srcpad,sinkpad);
|
||||||
|
|
||||||
if (!autoplugger->autoplug) {
|
if (!autoplugger->autoplug) {
|
||||||
autoplugger->autoplug = gst_autoplug_factory_make("static");
|
autoplugger->autoplug = gst_autoplug_factory_make("static");
|
||||||
g_return_val_if_fail(autoplugger->autoplug != NULL, FALSE);
|
g_return_val_if_fail(autoplugger->autoplug != NULL, FALSE);
|
||||||
}
|
}
|
||||||
GST_DEBUG(GST_CAT_AUTOPLUG, "building autoplugged bin between caps");
|
GST_DEBUG ("building autoplugged bin between caps");
|
||||||
autoplugger->autobin = gst_autoplug_to_caps(autoplugger->autoplug,
|
autoplugger->autobin = gst_autoplug_to_caps(autoplugger->autoplug,
|
||||||
srccaps,sinkcaps,NULL);
|
srccaps,sinkcaps,NULL);
|
||||||
g_return_val_if_fail(autoplugger->autobin != NULL, FALSE);
|
g_return_val_if_fail(autoplugger->autobin != NULL, FALSE);
|
||||||
|
@ -306,20 +310,20 @@ gst_autoplugger_autoplug(GstAutoplugger *autoplugger,GstPad *srcpad,GstCaps *src
|
||||||
gst_scheduler_show(GST_ELEMENT_SCHED(autoplugger));
|
gst_scheduler_show(GST_ELEMENT_SCHED(autoplugger));
|
||||||
|
|
||||||
/* FIXME this is a hack */
|
/* FIXME this is a hack */
|
||||||
/* GST_DEBUG(GST_CAT_AUTOPLUG, "copying failed caps to srcpad %s:%s to ensure renego",GST_DEBUG_PAD_NAME(autoplugger->cache_srcpad)); */
|
/* GST_DEBUG ("copying failed caps to srcpad %s:%s to ensure renego",GST_DEBUG_PAD_NAME(autoplugger->cache_srcpad)); */
|
||||||
/* gst_pad_set_caps(srcpad,srccaps); */
|
/* gst_pad_set_caps(srcpad,srccaps); */
|
||||||
|
|
||||||
if (GST_PAD_CAPS(srcpad) == NULL) GST_DEBUG(GST_CAT_AUTOPLUG,"no caps on cache:src!");
|
if (GST_PAD_CAPS(srcpad) == NULL) GST_DEBUG ("no caps on cache:src!");
|
||||||
|
|
||||||
/* attach the autoplugged bin */
|
/* attach the autoplugged bin */
|
||||||
GST_DEBUG(GST_CAT_AUTOPLUG, "attaching the autoplugged bin between the two pads");
|
GST_DEBUG ("attaching the autoplugged bin between the two pads");
|
||||||
gst_pad_link(srcpad,gst_element_get_pad(autoplugger->autobin,"sink"));
|
gst_pad_link(srcpad,gst_element_get_pad(autoplugger->autobin,"sink"));
|
||||||
gst_scheduler_show(GST_ELEMENT_SCHED(autoplugger));
|
gst_scheduler_show(GST_ELEMENT_SCHED(autoplugger));
|
||||||
gst_pad_link(gst_element_get_pad(autoplugger->autobin,"src_00"),sinkpad);
|
gst_pad_link(gst_element_get_pad(autoplugger->autobin,"src_00"),sinkpad);
|
||||||
gst_scheduler_show(GST_ELEMENT_SCHED(autoplugger));
|
gst_scheduler_show(GST_ELEMENT_SCHED(autoplugger));
|
||||||
|
|
||||||
/* FIXME try to force the renego */
|
/* FIXME try to force the renego */
|
||||||
/* GST_DEBUG(GST_CAT_AUTOPLUG, "trying to force everyone to nego"); */
|
/* GST_DEBUG ("trying to force everyone to nego"); */
|
||||||
/* gst_pad_renegotiate(gst_element_get_pad(autoplugger->autobin,"sink")); */
|
/* gst_pad_renegotiate(gst_element_get_pad(autoplugger->autobin,"sink")); */
|
||||||
/* gst_pad_renegotiate(sinkpad); */
|
/* gst_pad_renegotiate(sinkpad); */
|
||||||
|
|
||||||
|
@ -335,7 +339,7 @@ gst_autoplugger_external_sink_caps_nego_failed(GstPad *pad, gboolean *result, Gs
|
||||||
GstPad *sinkpad_peer;
|
GstPad *sinkpad_peer;
|
||||||
GstCaps *sinkpad_peer_caps;
|
GstCaps *sinkpad_peer_caps;
|
||||||
|
|
||||||
GST_INFO(GST_CAT_AUTOPLUG, "have caps nego failure on sinkpad %s:%s!!!",GST_DEBUG_PAD_NAME(pad));
|
GST_INFO ("have caps nego failure on sinkpad %s:%s!!!",GST_DEBUG_PAD_NAME(pad));
|
||||||
|
|
||||||
autoplugger->paused++;
|
autoplugger->paused++;
|
||||||
if (autoplugger->paused == 1)
|
if (autoplugger->paused == 1)
|
||||||
|
@ -362,7 +366,7 @@ gst_autoplugger_external_sink_caps_nego_failed(GstPad *pad, gboolean *result, Gs
|
||||||
/* try to PLAY the whole thing */
|
/* try to PLAY the whole thing */
|
||||||
gst_element_set_state(GST_ELEMENT_SCHED(autoplugger)->parent,GST_STATE_PLAYING);
|
gst_element_set_state(GST_ELEMENT_SCHED(autoplugger)->parent,GST_STATE_PLAYING);
|
||||||
|
|
||||||
GST_INFO(GST_CAT_AUTOPLUG, "done dealing with caps nego failure on sinkpad %s:%s",GST_DEBUG_PAD_NAME(pad));
|
GST_INFO ("done dealing with caps nego failure on sinkpad %s:%s",GST_DEBUG_PAD_NAME(pad));
|
||||||
}
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
|
@ -373,7 +377,7 @@ gst_autoplugger_external_src_caps_nego_failed(GstPad *pad, gboolean *result, Gst
|
||||||
GstPadTemplate *srcpad_peer_template;
|
GstPadTemplate *srcpad_peer_template;
|
||||||
GstCaps *srcpad_peer_caps;
|
GstCaps *srcpad_peer_caps;
|
||||||
|
|
||||||
GST_INFO(GST_CAT_AUTOPLUG, "have caps nego failure on srcpad %s:%s!!!",GST_DEBUG_PAD_NAME(pad));
|
GST_INFO ("have caps nego failure on srcpad %s:%s!!!",GST_DEBUG_PAD_NAME(pad));
|
||||||
|
|
||||||
autoplugger->paused++;
|
autoplugger->paused++;
|
||||||
if (autoplugger->paused == 1)
|
if (autoplugger->paused == 1)
|
||||||
|
@ -399,7 +403,7 @@ gst_autoplugger_external_src_caps_nego_failed(GstPad *pad, gboolean *result, Gst
|
||||||
|
|
||||||
autoplugger->disable_nocaps = TRUE;
|
autoplugger->disable_nocaps = TRUE;
|
||||||
|
|
||||||
GST_INFO(GST_CAT_AUTOPLUG, "done dealing with caps nego failure on srcpad %s:%s",GST_DEBUG_PAD_NAME(pad));
|
GST_INFO ("done dealing with caps nego failure on srcpad %s:%s",GST_DEBUG_PAD_NAME(pad));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@ -408,7 +412,7 @@ gst_autoplugger_cache_empty(GstElement *element, GstAutoplugger *autoplugger)
|
||||||
{
|
{
|
||||||
GstPad *cache_sinkpad_peer,*cache_srcpad_peer;
|
GstPad *cache_sinkpad_peer,*cache_srcpad_peer;
|
||||||
|
|
||||||
GST_INFO(GST_CAT_AUTOPLUG, "autoplugger cache has hit empty, we can now remove it");
|
GST_INFO ("autoplugger cache has hit empty, we can now remove it");
|
||||||
|
|
||||||
autoplugger->paused++;
|
autoplugger->paused++;
|
||||||
if (autoplugger->paused == 1)
|
if (autoplugger->paused == 1)
|
||||||
|
@ -416,18 +420,18 @@ gst_autoplugger_cache_empty(GstElement *element, GstAutoplugger *autoplugger)
|
||||||
gst_element_set_state(GST_ELEMENT_SCHED(autoplugger)->parent,GST_STATE_PAUSED);
|
gst_element_set_state(GST_ELEMENT_SCHED(autoplugger)->parent,GST_STATE_PAUSED);
|
||||||
|
|
||||||
/* unlink the cache from its peers */
|
/* unlink the cache from its peers */
|
||||||
GST_DEBUG(GST_CAT_AUTOPLUG, "unlinking autoplugcache from its peers");
|
GST_DEBUG ("unlinking autoplugcache from its peers");
|
||||||
cache_sinkpad_peer = GST_PAD (GST_PAD_PEER(autoplugger->cache_sinkpad));
|
cache_sinkpad_peer = GST_PAD (GST_PAD_PEER(autoplugger->cache_sinkpad));
|
||||||
cache_srcpad_peer = GST_PAD (GST_PAD_PEER(autoplugger->cache_srcpad));
|
cache_srcpad_peer = GST_PAD (GST_PAD_PEER(autoplugger->cache_srcpad));
|
||||||
gst_pad_unlink(cache_sinkpad_peer,autoplugger->cache_sinkpad);
|
gst_pad_unlink(cache_sinkpad_peer,autoplugger->cache_sinkpad);
|
||||||
gst_pad_unlink(autoplugger->cache_srcpad,cache_srcpad_peer);
|
gst_pad_unlink(autoplugger->cache_srcpad,cache_srcpad_peer);
|
||||||
|
|
||||||
/* remove the cache from self */
|
/* remove the cache from self */
|
||||||
GST_DEBUG(GST_CAT_AUTOPLUG, "removing the cache from the autoplugger");
|
GST_DEBUG ("removing the cache from the autoplugger");
|
||||||
gst_bin_remove (GST_BIN(autoplugger), autoplugger->cache);
|
gst_bin_remove (GST_BIN(autoplugger), autoplugger->cache);
|
||||||
|
|
||||||
/* link the two pads */
|
/* link the two pads */
|
||||||
GST_DEBUG(GST_CAT_AUTOPLUG, "relinking the autoplugcache's former peers");
|
GST_DEBUG ("relinking the autoplugcache's former peers");
|
||||||
gst_pad_link(cache_sinkpad_peer,cache_srcpad_peer);
|
gst_pad_link(cache_sinkpad_peer,cache_srcpad_peer);
|
||||||
|
|
||||||
autoplugger->paused--;
|
autoplugger->paused--;
|
||||||
|
@ -437,13 +441,13 @@ gst_autoplugger_cache_empty(GstElement *element, GstAutoplugger *autoplugger)
|
||||||
|
|
||||||
/* xmlSaveFile("autoplugger.gst", gst_xml_write(GST_ELEMENT_SCHED(autoplugger)->parent)); */
|
/* xmlSaveFile("autoplugger.gst", gst_xml_write(GST_ELEMENT_SCHED(autoplugger)->parent)); */
|
||||||
|
|
||||||
GST_INFO(GST_CAT_AUTOPLUG, "autoplugger_cache_empty finished");
|
GST_INFO ("autoplugger_cache_empty finished");
|
||||||
}
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
gst_autoplugger_type_find_have_type(GstElement *element, GstCaps *caps, GstAutoplugger *autoplugger)
|
gst_autoplugger_type_find_have_type(GstElement *element, GstCaps *caps, GstAutoplugger *autoplugger)
|
||||||
{
|
{
|
||||||
GST_INFO(GST_CAT_AUTOPLUG, "typefind claims to have a type: %s",gst_caps_get_mime(caps));
|
GST_INFO ("typefind claims to have a type: %s",gst_caps_get_mime(caps));
|
||||||
|
|
||||||
gst_scheduler_show(GST_ELEMENT_SCHED(autoplugger));
|
gst_scheduler_show(GST_ELEMENT_SCHED(autoplugger));
|
||||||
|
|
||||||
|
@ -453,7 +457,7 @@ gst_scheduler_show(GST_ELEMENT_SCHED(autoplugger));
|
||||||
gst_element_set_state(GST_ELEMENT_SCHED(autoplugger)->parent,GST_STATE_PAUSED);
|
gst_element_set_state(GST_ELEMENT_SCHED(autoplugger)->parent,GST_STATE_PAUSED);
|
||||||
|
|
||||||
/* first unlink the typefind and shut it down */
|
/* first unlink the typefind and shut it down */
|
||||||
GST_DEBUG(GST_CAT_AUTOPLUG, "unlinking typefind from the cache");
|
GST_DEBUG ("unlinking typefind from the cache");
|
||||||
gst_pad_unlink(autoplugger->cache_srcpad,autoplugger->typefind_sinkpad);
|
gst_pad_unlink(autoplugger->cache_srcpad,autoplugger->typefind_sinkpad);
|
||||||
gst_bin_remove(GST_BIN(autoplugger),autoplugger->typefind);
|
gst_bin_remove(GST_BIN(autoplugger),autoplugger->typefind);
|
||||||
|
|
||||||
|
@ -470,25 +474,25 @@ gst_scheduler_show(GST_ELEMENT_SCHED(autoplugger));
|
||||||
gst_bin_add(GST_BIN(autoplugger),autoplugger->autobin);
|
gst_bin_add(GST_BIN(autoplugger),autoplugger->autobin);
|
||||||
|
|
||||||
* * re-attach the srcpad's original peer to the cache *
|
* * re-attach the srcpad's original peer to the cache *
|
||||||
* GST_DEBUG(GST_CAT_AUTOPLUG, "relinking the cache to the downstream peer"); *
|
* GST_DEBUG ("relinking the cache to the downstream peer"); *
|
||||||
* gst_pad_link(autoplugger->cache_srcpad,autoplugger->srcpadpeer); *
|
* gst_pad_link(autoplugger->cache_srcpad,autoplugger->srcpadpeer); *
|
||||||
|
|
||||||
* attach the autoplugged bin *
|
* attach the autoplugged bin *
|
||||||
GST_DEBUG(GST_CAT_AUTOPLUG, "attaching the autoplugged bin between cache and downstream peer");
|
GST_DEBUG ("attaching the autoplugged bin between cache and downstream peer");
|
||||||
gst_pad_link(autoplugger->cache_srcpad,gst_element_get_pad(autoplugger->autobin,"sink"));
|
gst_pad_link(autoplugger->cache_srcpad,gst_element_get_pad(autoplugger->autobin,"sink"));
|
||||||
gst_pad_link(gst_element_get_pad(autoplugger->autobin,"src_00"),autoplugger->srcpadpeer);
|
gst_pad_link(gst_element_get_pad(autoplugger->autobin,"src_00"),autoplugger->srcpadpeer);
|
||||||
*/
|
*/
|
||||||
|
|
||||||
/* FIXME set the caps on the new link
|
/* FIXME set the caps on the new link
|
||||||
* GST_DEBUG(GST_CAT_AUTOPLUG,"forcing caps on the typefound pad");
|
* GST_DEBUG ("forcing caps on the typefound pad");
|
||||||
* gst_pad_set_caps(autoplugger->cache_srcpad,caps);
|
* gst_pad_set_caps(autoplugger->cache_srcpad,caps);
|
||||||
* reattach the original outside srcpad
|
* reattach the original outside srcpad
|
||||||
*/
|
*/
|
||||||
GST_DEBUG(GST_CAT_AUTOPLUG,"re-attaching downstream peer to autoplugcache");
|
GST_DEBUG ("re-attaching downstream peer to autoplugcache");
|
||||||
gst_pad_link(autoplugger->cache_srcpad,autoplugger->srcpadpeer);
|
gst_pad_link(autoplugger->cache_srcpad,autoplugger->srcpadpeer);
|
||||||
|
|
||||||
/* now reset the autoplugcache */
|
/* now reset the autoplugcache */
|
||||||
GST_DEBUG(GST_CAT_AUTOPLUG, "resetting the cache to send first buffer(s) again");
|
GST_DEBUG ("resetting the cache to send first buffer(s) again");
|
||||||
g_object_set(G_OBJECT(autoplugger->cache),"reset",TRUE,NULL);
|
g_object_set(G_OBJECT(autoplugger->cache),"reset",TRUE,NULL);
|
||||||
|
|
||||||
/* attach the cache_empty handler */
|
/* attach the cache_empty handler */
|
||||||
|
@ -501,22 +505,22 @@ gst_scheduler_show(GST_ELEMENT_SCHED(autoplugger));
|
||||||
/* try to PLAY the whole thing */
|
/* try to PLAY the whole thing */
|
||||||
gst_element_set_state(GST_ELEMENT_SCHED(autoplugger)->parent,GST_STATE_PLAYING);
|
gst_element_set_state(GST_ELEMENT_SCHED(autoplugger)->parent,GST_STATE_PLAYING);
|
||||||
|
|
||||||
GST_INFO(GST_CAT_AUTOPLUG, "typefind_have_type finished");
|
GST_INFO ("typefind_have_type finished");
|
||||||
gst_scheduler_show(GST_ELEMENT_SCHED(autoplugger));
|
gst_scheduler_show(GST_ELEMENT_SCHED(autoplugger));
|
||||||
}
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
gst_autoplugger_cache_first_buffer(GstElement *element,GstBuffer *buf,GstAutoplugger *autoplugger)
|
gst_autoplugger_cache_first_buffer(GstElement *element,GstBuffer *buf,GstAutoplugger *autoplugger)
|
||||||
{
|
{
|
||||||
GST_INFO(GST_CAT_AUTOPLUG, "have first buffer through cache");
|
GST_INFO ("have first buffer through cache");
|
||||||
autoplugger->cache_first_buffer = TRUE;
|
autoplugger->cache_first_buffer = TRUE;
|
||||||
|
|
||||||
/* if there are no established caps, worry */
|
/* if there are no established caps, worry */
|
||||||
if (!autoplugger->sinkcaps) {
|
if (!autoplugger->sinkcaps) {
|
||||||
GST_INFO(GST_CAT_AUTOPLUG, "have no caps for the buffer, Danger Will Robinson!");
|
GST_INFO ("have no caps for the buffer, Danger Will Robinson!");
|
||||||
|
|
||||||
if (autoplugger->disable_nocaps) {
|
if (autoplugger->disable_nocaps) {
|
||||||
GST_DEBUG(GST_CAT_AUTOPLUG, "not dealing with lack of caps this time");
|
GST_DEBUG ("not dealing with lack of caps this time");
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -528,25 +532,25 @@ gst_scheduler_show(GST_ELEMENT_SCHED(autoplugger));
|
||||||
gst_element_set_state(GST_ELEMENT_SCHED(autoplugger)->parent,GST_STATE_PAUSED);
|
gst_element_set_state(GST_ELEMENT_SCHED(autoplugger)->parent,GST_STATE_PAUSED);
|
||||||
|
|
||||||
/* detach the srcpad */
|
/* detach the srcpad */
|
||||||
GST_DEBUG(GST_CAT_AUTOPLUG, "unlinking cache from its downstream peer");
|
GST_DEBUG ("unlinking cache from its downstream peer");
|
||||||
autoplugger->srcpadpeer = GST_PAD(GST_PAD_PEER(autoplugger->cache_srcpad));
|
autoplugger->srcpadpeer = GST_PAD(GST_PAD_PEER(autoplugger->cache_srcpad));
|
||||||
gst_pad_unlink(autoplugger->cache_srcpad,autoplugger->srcpadpeer);
|
gst_pad_unlink(autoplugger->cache_srcpad,autoplugger->srcpadpeer);
|
||||||
|
|
||||||
/* instantiate the typefind and set up the signal handlers */
|
/* instantiate the typefind and set up the signal handlers */
|
||||||
if (!autoplugger->typefind) {
|
if (!autoplugger->typefind) {
|
||||||
GST_DEBUG(GST_CAT_AUTOPLUG, "creating typefind and setting signal handler");
|
GST_DEBUG ("creating typefind and setting signal handler");
|
||||||
autoplugger->typefind = gst_element_factory_make("typefind","unnamed_type_find");
|
autoplugger->typefind = gst_element_factory_make("typefind","unnamed_type_find");
|
||||||
autoplugger->typefind_sinkpad = gst_element_get_pad(autoplugger->typefind,"sink");
|
autoplugger->typefind_sinkpad = gst_element_get_pad(autoplugger->typefind,"sink");
|
||||||
g_signal_connect (G_OBJECT(autoplugger->typefind),"have_type",
|
g_signal_connect (G_OBJECT(autoplugger->typefind),"have_type",
|
||||||
G_CALLBACK (gst_autoplugger_type_find_have_type), autoplugger);
|
G_CALLBACK (gst_autoplugger_type_find_have_type), autoplugger);
|
||||||
}
|
}
|
||||||
/* add it to self and attach it */
|
/* add it to self and attach it */
|
||||||
GST_DEBUG(GST_CAT_AUTOPLUG, "adding typefind to self and linking to cache");
|
GST_DEBUG ("adding typefind to self and linking to cache");
|
||||||
gst_bin_add(GST_BIN(autoplugger),autoplugger->typefind);
|
gst_bin_add(GST_BIN(autoplugger),autoplugger->typefind);
|
||||||
gst_pad_link(autoplugger->cache_srcpad,autoplugger->typefind_sinkpad);
|
gst_pad_link(autoplugger->cache_srcpad,autoplugger->typefind_sinkpad);
|
||||||
|
|
||||||
/* bring the typefind into playing state */
|
/* bring the typefind into playing state */
|
||||||
GST_DEBUG(GST_CAT_AUTOPLUG, "setting typefind state to PLAYING");
|
GST_DEBUG ("setting typefind state to PLAYING");
|
||||||
gst_element_set_state(autoplugger->cache,GST_STATE_PLAYING);
|
gst_element_set_state(autoplugger->cache,GST_STATE_PLAYING);
|
||||||
|
|
||||||
autoplugger->paused--;
|
autoplugger->paused--;
|
||||||
|
@ -554,7 +558,7 @@ gst_scheduler_show(GST_ELEMENT_SCHED(autoplugger));
|
||||||
/* try to PLAY the whole thing */
|
/* try to PLAY the whole thing */
|
||||||
gst_element_set_state(GST_ELEMENT_SCHED(autoplugger)->parent,GST_STATE_PLAYING);
|
gst_element_set_state(GST_ELEMENT_SCHED(autoplugger)->parent,GST_STATE_PLAYING);
|
||||||
|
|
||||||
GST_INFO(GST_CAT_AUTOPLUG,"here we go into nothingness, hoping the typefind will return us to safety");
|
GST_INFO ("here we go into nothingness, hoping the typefind will return us to safety");
|
||||||
gst_scheduler_show(GST_ELEMENT_SCHED(autoplugger));
|
gst_scheduler_show(GST_ELEMENT_SCHED(autoplugger));
|
||||||
} else {
|
} else {
|
||||||
/* * attach the cache_empty handler, since the cache simply isn't needed *
|
/* * attach the cache_empty handler, since the cache simply isn't needed *
|
||||||
|
|
|
@ -21,12 +21,22 @@
|
||||||
* Boston, MA 02111-1307, USA.
|
* Boston, MA 02111-1307, USA.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
#ifdef HAVE_CONFIG_H
|
||||||
|
# include "config.h"
|
||||||
|
#endif
|
||||||
|
|
||||||
#include "gstsearchfuncs.h"
|
#include "gstsearchfuncs.h"
|
||||||
|
|
||||||
|
/* FIXME: "evil hack" alarm, we need a better way to get a category in here */
|
||||||
|
#ifndef GST_DISABLE_GST_DEBUG
|
||||||
|
extern GstDebugCategory *GST_CAT_AUTOPLUG_ATTEMPT;
|
||||||
|
#define GST_CAT_DEFAULT GST_CAT_AUTOPLUG_ATTEMPT
|
||||||
|
#endif
|
||||||
|
|
||||||
/* function that really misses in GLib
|
/* function that really misses in GLib
|
||||||
* though the GLib version should take a function as argument...
|
* though the GLib version should take a function as argument...
|
||||||
*/
|
*/
|
||||||
void
|
static void
|
||||||
g_list_free_list_and_elements (GList *list)
|
g_list_free_list_and_elements (GList *list)
|
||||||
{
|
{
|
||||||
GList *walk = list;
|
GList *walk = list;
|
||||||
|
@ -145,8 +155,7 @@ gst_autoplug_can_match (GstElementFactory *src, GstElementFactory *dest)
|
||||||
desttemp->direction == GST_PAD_SINK) {
|
desttemp->direction == GST_PAD_SINK) {
|
||||||
if (gst_autoplug_caps_intersect (gst_pad_template_get_caps (srctemp),
|
if (gst_autoplug_caps_intersect (gst_pad_template_get_caps (srctemp),
|
||||||
gst_pad_template_get_caps (desttemp))) {
|
gst_pad_template_get_caps (desttemp))) {
|
||||||
GST_DEBUG (GST_CAT_AUTOPLUG_ATTEMPT,
|
GST_DEBUG ("factory \"%s\" can connect with factory \"%s\"",
|
||||||
"factory \"%s\" can connect with factory \"%s\"",
|
|
||||||
GST_OBJECT_NAME (src), GST_OBJECT_NAME (dest));
|
GST_OBJECT_NAME (src), GST_OBJECT_NAME (dest));
|
||||||
return desttemp;
|
return desttemp;
|
||||||
}
|
}
|
||||||
|
@ -156,8 +165,7 @@ gst_autoplug_can_match (GstElementFactory *src, GstElementFactory *dest)
|
||||||
}
|
}
|
||||||
srctemps = g_list_next (srctemps);
|
srctemps = g_list_next (srctemps);
|
||||||
}
|
}
|
||||||
GST_DEBUG (GST_CAT_AUTOPLUG_ATTEMPT,
|
GST_DEBUG ("factory \"%s\" cannot connect with factory \"%s\"",
|
||||||
"factory \"%s\" cannot connect with factory \"%s\"",
|
|
||||||
GST_OBJECT_NAME (src), GST_OBJECT_NAME (dest));
|
GST_OBJECT_NAME (src), GST_OBJECT_NAME (dest));
|
||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
|
@ -331,8 +339,7 @@ gst_autoplug_sp (GstCaps *srccaps, GstCaps *sinkcaps, GList *factories)
|
||||||
g_return_val_if_fail (srccaps != NULL, NULL);
|
g_return_val_if_fail (srccaps != NULL, NULL);
|
||||||
g_return_val_if_fail (sinkcaps != NULL, NULL);
|
g_return_val_if_fail (sinkcaps != NULL, NULL);
|
||||||
|
|
||||||
GST_INFO (GST_CAT_AUTOPLUG_ATTEMPT,
|
GST_INFO ("attempting to autoplug via shortest path from %s to %s",
|
||||||
"attempting to autoplug via shortest path from %s to %s",
|
|
||||||
gst_caps_get_mime (srccaps), gst_caps_get_mime (sinkcaps));
|
gst_caps_get_mime (srccaps), gst_caps_get_mime (sinkcaps));
|
||||||
gst_caps_debug (srccaps, "source caps");
|
gst_caps_debug (srccaps, "source caps");
|
||||||
gst_caps_debug (sinkcaps, "sink caps");
|
gst_caps_debug (sinkcaps, "sink caps");
|
||||||
|
@ -343,18 +350,16 @@ gst_autoplug_sp (GstCaps *srccaps, GstCaps *sinkcaps, GList *factories)
|
||||||
GstAutoplugNode *node = g_new0 (GstAutoplugNode, 1);
|
GstAutoplugNode *node = g_new0 (GstAutoplugNode, 1);
|
||||||
node->prev = NULL;
|
node->prev = NULL;
|
||||||
node->fac = (GstElementFactory *) factories->data;
|
node->fac = (GstElementFactory *) factories->data;
|
||||||
GST_DEBUG (GST_CAT_AUTOPLUG_ATTEMPT,
|
GST_DEBUG ("trying with %s", node->fac->details->longname);
|
||||||
"trying with %s", node->fac->details->longname);
|
|
||||||
node->templ = gst_autoplug_can_connect_src (node->fac, srccaps);
|
node->templ = gst_autoplug_can_connect_src (node->fac, srccaps);
|
||||||
node->cost = (node->templ ? gst_autoplug_get_cost (node->fac)
|
node->cost = (node->templ ? gst_autoplug_get_cost (node->fac)
|
||||||
: GST_AUTOPLUG_MAX_COST);
|
: GST_AUTOPLUG_MAX_COST);
|
||||||
node->endpoint = gst_autoplug_can_connect_sink (node->fac, sinkcaps);
|
node->endpoint = gst_autoplug_can_connect_sink (node->fac, sinkcaps);
|
||||||
if (node->templ && node->endpoint)
|
if (node->templ && node->endpoint)
|
||||||
GST_DEBUG (GST_CAT_AUTOPLUG_ATTEMPT, "%s makes connection possible",
|
GST_DEBUG ("%s makes connection possible",
|
||||||
node->fac->details->longname);
|
node->fac->details->longname);
|
||||||
else
|
else
|
||||||
GST_DEBUG (GST_CAT_AUTOPLUG_ATTEMPT,
|
GST_DEBUG ("direct connection with %s not possible",
|
||||||
"direct connection with %s not possible",
|
|
||||||
node->fac->details->longname);
|
node->fac->details->longname);
|
||||||
if ((node->endpoint != NULL) &&
|
if ((node->endpoint != NULL) &&
|
||||||
((bestnode == NULL) || (node->cost < bestnode->cost)))
|
((bestnode == NULL) || (node->cost < bestnode->cost)))
|
||||||
|
@ -370,8 +375,7 @@ gst_autoplug_sp (GstCaps *srccaps, GstCaps *sinkcaps, GList *factories)
|
||||||
/* check if we even have possible endpoints */
|
/* check if we even have possible endpoints */
|
||||||
if (bestnode == NULL)
|
if (bestnode == NULL)
|
||||||
{
|
{
|
||||||
GST_DEBUG (GST_CAT_AUTOPLUG_ATTEMPT,
|
GST_DEBUG ("no factory found that could connect to sink caps");
|
||||||
"no factory found that could connect to sink caps");
|
|
||||||
g_list_free_list_and_elements (factory_nodes);
|
g_list_free_list_and_elements (factory_nodes);
|
||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
|
@ -381,12 +385,12 @@ gst_autoplug_sp (GstCaps *srccaps, GstCaps *sinkcaps, GList *factories)
|
||||||
{
|
{
|
||||||
GList *nodes = factory_nodes;
|
GList *nodes = factory_nodes;
|
||||||
guint nextcost = GST_AUTOPLUG_MAX_COST; /* next cost to check */
|
guint nextcost = GST_AUTOPLUG_MAX_COST; /* next cost to check */
|
||||||
GST_DEBUG (GST_CAT_AUTOPLUG_ATTEMPT, "iterating at current cost %d, bestnode %s at %d", curcost, GST_OBJECT_NAME (bestnode->fac), bestnode->cost);
|
GST_DEBUG ("iterating at current cost %d, bestnode %s at %d", curcost, GST_OBJECT_NAME (bestnode->fac), bestnode->cost);
|
||||||
/* check if we already have a valid best connection to the sink */
|
/* check if we already have a valid best connection to the sink */
|
||||||
if (bestnode->cost <= curcost)
|
if (bestnode->cost <= curcost)
|
||||||
{
|
{
|
||||||
GList *ret;
|
GList *ret;
|
||||||
GST_DEBUG (GST_CAT_AUTOPLUG_ATTEMPT, "found a way to connect via %s", GST_OBJECT_NAME ((GstObject *) bestnode->fac));
|
GST_DEBUG ("found a way to connect via %s", GST_OBJECT_NAME ((GstObject *) bestnode->fac));
|
||||||
/* enter all factories into the return list */
|
/* enter all factories into the return list */
|
||||||
ret = g_list_prepend (NULL, bestnode->fac);
|
ret = g_list_prepend (NULL, bestnode->fac);
|
||||||
bestnode = bestnode->prev;
|
bestnode = bestnode->prev;
|
||||||
|
@ -440,12 +444,7 @@ gst_autoplug_sp (GstCaps *srccaps, GstCaps *sinkcaps, GList *factories)
|
||||||
curcost = nextcost;
|
curcost = nextcost;
|
||||||
}
|
}
|
||||||
|
|
||||||
GST_DEBUG (GST_CAT_AUTOPLUG_ATTEMPT, "found no path from source caps to sink caps");
|
GST_DEBUG ("found no path from source caps to sink caps");
|
||||||
g_list_free_list_and_elements (factory_nodes);
|
g_list_free_list_and_elements (factory_nodes);
|
||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
|
@ -41,10 +41,17 @@
|
||||||
* ...
|
* ...
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
#ifdef HAVE_CONFIG_H
|
||||||
|
# include "config.h"
|
||||||
|
#endif
|
||||||
|
|
||||||
#include "gstspider.h"
|
#include "gstspider.h"
|
||||||
#include "gstspideridentity.h"
|
#include "gstspideridentity.h"
|
||||||
#include "gstsearchfuncs.h"
|
#include "gstsearchfuncs.h"
|
||||||
|
|
||||||
|
GST_DEBUG_CATEGORY (gst_spider_debug);
|
||||||
|
#define GST_CAT_DEFAULT gst_spider_debug
|
||||||
|
|
||||||
/* signals and args */
|
/* signals and args */
|
||||||
enum {
|
enum {
|
||||||
/* FILL ME */
|
/* FILL ME */
|
||||||
|
@ -202,7 +209,7 @@ gst_spider_request_new_pad (GstElement *element, GstPadTemplate *templ, const gc
|
||||||
|
|
||||||
returnpad = gst_element_add_ghost_pad (element, returnpad, padname);
|
returnpad = gst_element_add_ghost_pad (element, returnpad, padname);
|
||||||
gst_spider_link_new (identity);
|
gst_spider_link_new (identity);
|
||||||
GST_DEBUG (GST_CAT_ELEMENT_PADS, "successuflly created requested pad %s:%s", GST_DEBUG_PAD_NAME (returnpad));
|
GST_DEBUG ("successuflly created requested pad %s:%s", GST_DEBUG_PAD_NAME (returnpad));
|
||||||
|
|
||||||
return returnpad;
|
return returnpad;
|
||||||
}
|
}
|
||||||
|
@ -270,11 +277,11 @@ static void
|
||||||
gst_spider_link_sometimes (GstElement *src, GstPad *pad, GstSpiderConnection *conn)
|
gst_spider_link_sometimes (GstElement *src, GstPad *pad, GstSpiderConnection *conn)
|
||||||
{
|
{
|
||||||
gulong signal_id = conn->signal_id;
|
gulong signal_id = conn->signal_id;
|
||||||
GstPad *sinkpad = conn->src->sink;
|
|
||||||
|
|
||||||
/* try to autoplug the elements */
|
/* try to autoplug the elements */
|
||||||
if (gst_spider_plug_from_srcpad (conn, pad) != GST_PAD_LINK_REFUSED) {
|
if (gst_spider_plug_from_srcpad (conn, pad) != GST_PAD_LINK_REFUSED) {
|
||||||
GST_DEBUG (GST_CAT_AUTOPLUG_ATTEMPT, "%s:%s was autoplugged to %s:%s, removing callback", GST_DEBUG_PAD_NAME (pad), GST_DEBUG_PAD_NAME (sinkpad));
|
GST_DEBUG ("%s:%s was autoplugged to %s:%s, removing callback",
|
||||||
|
GST_DEBUG_PAD_NAME (pad), GST_DEBUG_PAD_NAME (conn->src->sink));
|
||||||
g_signal_handler_disconnect (src, signal_id);
|
g_signal_handler_disconnect (src, signal_id);
|
||||||
signal_id = 0;
|
signal_id = 0;
|
||||||
}
|
}
|
||||||
|
@ -305,7 +312,7 @@ static void
|
||||||
gst_spider_link_reset (GstSpiderConnection *conn, GstElement *to)
|
gst_spider_link_reset (GstSpiderConnection *conn, GstElement *to)
|
||||||
{
|
{
|
||||||
GstSpider *spider = GST_SPIDER (GST_OBJECT_PARENT (conn->src));
|
GstSpider *spider = GST_SPIDER (GST_OBJECT_PARENT (conn->src));
|
||||||
GST_DEBUG (GST_CAT_AUTOPLUG, "resetting link from %s to %s, currently at %s to %s", GST_ELEMENT_NAME (spider->sink_ident),
|
GST_DEBUG ("resetting link from %s to %s, currently at %s to %s", GST_ELEMENT_NAME (spider->sink_ident),
|
||||||
GST_ELEMENT_NAME (conn->src), GST_ELEMENT_NAME (conn->current), GST_ELEMENT_NAME (to));
|
GST_ELEMENT_NAME (conn->src), GST_ELEMENT_NAME (conn->current), GST_ELEMENT_NAME (to));
|
||||||
while ((conn->path != NULL) && ((GstElement *) conn->path->data != to))
|
while ((conn->path != NULL) && ((GstElement *) conn->path->data != to))
|
||||||
{
|
{
|
||||||
|
@ -487,7 +494,7 @@ gst_spider_create_and_plug (GstSpiderConnection *conn, GList *plugpath)
|
||||||
element = (GstElement *) (endelements == NULL ? conn->src : endelements->data);
|
element = (GstElement *) (endelements == NULL ? conn->src : endelements->data);
|
||||||
} else {
|
} else {
|
||||||
element = gst_element_factory_create ((GstElementFactory *) plugpath->data, NULL);
|
element = gst_element_factory_create ((GstElementFactory *) plugpath->data, NULL);
|
||||||
GST_DEBUG (GST_CAT_AUTOPLUG_ATTEMPT, "Adding element %s of type %s and syncing state with autoplugger",
|
GST_DEBUG ("Adding element %s of type %s and syncing state with autoplugger",
|
||||||
GST_ELEMENT_NAME (element), GST_PLUGIN_FEATURE_NAME (plugpath->data));
|
GST_ELEMENT_NAME (element), GST_PLUGIN_FEATURE_NAME (plugpath->data));
|
||||||
gst_bin_add (GST_BIN (spider), element);
|
gst_bin_add (GST_BIN (spider), element);
|
||||||
}
|
}
|
||||||
|
@ -506,7 +513,7 @@ gst_spider_create_and_plug (GstSpiderConnection *conn, GList *plugpath)
|
||||||
GstPadTemplate *templ = (GstPadTemplate *) templs->data;
|
GstPadTemplate *templ = (GstPadTemplate *) templs->data;
|
||||||
if ((GST_PAD_TEMPLATE_DIRECTION (templ) == GST_PAD_SRC) && (GST_PAD_TEMPLATE_PRESENCE(templ) == GST_PAD_SOMETIMES))
|
if ((GST_PAD_TEMPLATE_DIRECTION (templ) == GST_PAD_SRC) && (GST_PAD_TEMPLATE_PRESENCE(templ) == GST_PAD_SOMETIMES))
|
||||||
{
|
{
|
||||||
GST_DEBUG (GST_CAT_AUTOPLUG_ATTEMPT, "adding callback to link element %s to %s", GST_ELEMENT_NAME (conn->current), GST_ELEMENT_NAME (conn->src));
|
GST_DEBUG ("adding callback to link element %s to %s", GST_ELEMENT_NAME (conn->current), GST_ELEMENT_NAME (conn->src));
|
||||||
conn->signal_id = g_signal_connect (G_OBJECT (conn->current), "new_pad",
|
conn->signal_id = g_signal_connect (G_OBJECT (conn->current), "new_pad",
|
||||||
G_CALLBACK (gst_spider_link_sometimes), conn);
|
G_CALLBACK (gst_spider_link_sometimes), conn);
|
||||||
g_list_free (plugpath);
|
g_list_free (plugpath);
|
||||||
|
@ -514,11 +521,11 @@ gst_spider_create_and_plug (GstSpiderConnection *conn, GList *plugpath)
|
||||||
}
|
}
|
||||||
templs = g_list_next (templs);
|
templs = g_list_next (templs);
|
||||||
}
|
}
|
||||||
GST_DEBUG (GST_CAT_AUTOPLUG_ATTEMPT, "no chance to link element %s to %s", GST_ELEMENT_NAME (conn->current), GST_ELEMENT_NAME (conn->src));
|
GST_DEBUG ("no chance to link element %s to %s", GST_ELEMENT_NAME (conn->current), GST_ELEMENT_NAME (conn->src));
|
||||||
g_list_free (plugpath);
|
g_list_free (plugpath);
|
||||||
return GST_PAD_LINK_REFUSED;
|
return GST_PAD_LINK_REFUSED;
|
||||||
}
|
}
|
||||||
GST_DEBUG (GST_CAT_AUTOPLUG_ATTEMPT, "added element %s and attached it to element %s", GST_ELEMENT_NAME (element), GST_ELEMENT_NAME (conn->current));
|
GST_DEBUG ("added element %s and attached it to element %s", GST_ELEMENT_NAME (element), GST_ELEMENT_NAME (conn->current));
|
||||||
gst_spider_link_add (conn, element);
|
gst_spider_link_add (conn, element);
|
||||||
if (plugpath != NULL)
|
if (plugpath != NULL)
|
||||||
plugpath = g_list_delete_link (plugpath, plugpath);
|
plugpath = g_list_delete_link (plugpath, plugpath);
|
||||||
|
@ -579,7 +586,7 @@ gst_spider_plug_from_srcpad (GstSpiderConnection *conn, GstPad *srcpad)
|
||||||
GstElement *startelement = conn->current;
|
GstElement *startelement = conn->current;
|
||||||
|
|
||||||
g_assert ((GstElement *) GST_OBJECT_PARENT (srcpad) == conn->current);
|
g_assert ((GstElement *) GST_OBJECT_PARENT (srcpad) == conn->current);
|
||||||
GST_DEBUG (GST_CAT_AUTOPLUG_ATTEMPT, "trying to plug from %s:%s to %s",
|
GST_DEBUG ("trying to plug from %s:%s to %s",
|
||||||
GST_DEBUG_PAD_NAME (srcpad), GST_ELEMENT_NAME (conn->src));
|
GST_DEBUG_PAD_NAME (srcpad), GST_ELEMENT_NAME (conn->src));
|
||||||
|
|
||||||
/* find a path from src to sink */
|
/* find a path from src to sink */
|
||||||
|
@ -596,10 +603,10 @@ gst_spider_plug_from_srcpad (GstSpiderConnection *conn, GstPad *srcpad)
|
||||||
|
|
||||||
/* if there is no way to plug: return */
|
/* if there is no way to plug: return */
|
||||||
if (plugpath == NULL) {
|
if (plugpath == NULL) {
|
||||||
GST_DEBUG (GST_CAT_AUTOPLUG_ATTEMPT, "no chance to plug from %s to %s", GST_ELEMENT_NAME (conn->current), GST_ELEMENT_NAME (conn->src));
|
GST_DEBUG ("no chance to plug from %s to %s", GST_ELEMENT_NAME (conn->current), GST_ELEMENT_NAME (conn->src));
|
||||||
return GST_PAD_LINK_REFUSED;
|
return GST_PAD_LINK_REFUSED;
|
||||||
}
|
}
|
||||||
GST_DEBUG (GST_CAT_AUTOPLUG_ATTEMPT, "found a link that needs %d elements", g_list_length (plugpath));
|
GST_DEBUG ("found a link that needs %d elements", g_list_length (plugpath));
|
||||||
|
|
||||||
/* now remove non-needed elements from the beginning of the path
|
/* now remove non-needed elements from the beginning of the path
|
||||||
* alter src to point to the new element where we need to start
|
* alter src to point to the new element where we need to start
|
||||||
|
@ -612,7 +619,7 @@ gst_spider_plug_from_srcpad (GstSpiderConnection *conn, GstPad *srcpad)
|
||||||
plugpath = g_list_delete_link (plugpath, plugpath);
|
plugpath = g_list_delete_link (plugpath, plugpath);
|
||||||
}
|
}
|
||||||
|
|
||||||
GST_DEBUG (GST_CAT_AUTOPLUG_ATTEMPT, "%d elements must be inserted to establish the link", g_list_length (plugpath));
|
GST_DEBUG ("%d elements must be inserted to establish the link", g_list_length (plugpath));
|
||||||
/* create the elements and plug them */
|
/* create the elements and plug them */
|
||||||
result = gst_spider_create_and_plug (conn, plugpath);
|
result = gst_spider_create_and_plug (conn, plugpath);
|
||||||
|
|
||||||
|
@ -640,6 +647,9 @@ plugin_init (GModule *module, GstPlugin *plugin)
|
||||||
{
|
{
|
||||||
GstElementFactory *factory;
|
GstElementFactory *factory;
|
||||||
|
|
||||||
|
GST_DEBUG_CATEGORY_INIT (gst_spider_debug, "spider", 0, "spider autoplugging element");
|
||||||
|
GST_DEBUG_CATEGORY_INIT (gst_spider_identity_debug, "spideridentity", 0, "spider autoplugging proxy element");
|
||||||
|
|
||||||
factory = gst_element_factory_new("spider", GST_TYPE_SPIDER,
|
factory = gst_element_factory_new("spider", GST_TYPE_SPIDER,
|
||||||
&gst_spider_details);
|
&gst_spider_details);
|
||||||
gst_plugin_set_longname (plugin, "Spider autoplugging elements");
|
gst_plugin_set_longname (plugin, "Spider autoplugging elements");
|
||||||
|
|
|
@ -29,6 +29,7 @@
|
||||||
G_BEGIN_DECLS
|
G_BEGIN_DECLS
|
||||||
|
|
||||||
extern GstElementDetails gst_spider_details;
|
extern GstElementDetails gst_spider_details;
|
||||||
|
GST_DEBUG_CATEGORY_EXTERN(gst_spider_debug);
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Theory of operation:
|
* Theory of operation:
|
||||||
|
|
|
@ -20,11 +20,16 @@
|
||||||
* Boston, MA 02111-1307, USA.
|
* Boston, MA 02111-1307, USA.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
#ifdef HAVE_CONFIG_H
|
||||||
|
# include "config.h"
|
||||||
|
#endif
|
||||||
|
|
||||||
#include "gstspideridentity.h"
|
#include "gstspideridentity.h"
|
||||||
|
|
||||||
#include "gstspider.h"
|
#include "gstspider.h"
|
||||||
|
|
||||||
|
GST_DEBUG_CATEGORY (gst_spider_identity_debug);
|
||||||
|
#define GST_CAT_DEFAULT gst_spider_identity_debug
|
||||||
|
|
||||||
GstElementDetails gst_spider_identity_details = {
|
GstElementDetails gst_spider_identity_details = {
|
||||||
"SpiderIdentity",
|
"SpiderIdentity",
|
||||||
"Generic",
|
"Generic",
|
||||||
|
@ -179,7 +184,7 @@ gst_spider_identity_chain (GstPad *pad, GstBuffer *buf)
|
||||||
GstSpiderConnection *conn = (GstSpiderConnection *) list->data;
|
GstSpiderConnection *conn = (GstSpiderConnection *) list->data;
|
||||||
list = g_list_next (list);
|
list = g_list_next (list);
|
||||||
if (conn->current != (GstElement *) conn->src) {
|
if (conn->current != (GstElement *) conn->src) {
|
||||||
GST_DEBUG (GST_CAT_AUTOPLUG, "sending EOS to unconnected element %s from %s",
|
GST_DEBUG ("sending EOS to unconnected element %s from %s",
|
||||||
GST_ELEMENT_NAME (conn->src), GST_ELEMENT_NAME (ident));
|
GST_ELEMENT_NAME (conn->src), GST_ELEMENT_NAME (ident));
|
||||||
gst_pad_push (conn->src->src, GST_BUFFER (gst_event_new (GST_EVENT_EOS)));
|
gst_pad_push (conn->src->src, GST_BUFFER (gst_event_new (GST_EVENT_EOS)));
|
||||||
gst_element_set_eos (GST_ELEMENT (conn->src));
|
gst_element_set_eos (GST_ELEMENT (conn->src));
|
||||||
|
@ -194,7 +199,7 @@ gst_spider_identity_chain (GstPad *pad, GstBuffer *buf)
|
||||||
|
|
||||||
if ((ident->src != NULL) && (GST_PAD_PEER (ident->src) != NULL)) {
|
if ((ident->src != NULL) && (GST_PAD_PEER (ident->src) != NULL)) {
|
||||||
/* g_print("pushing buffer %p (refcount %d - buffersize %d) to pad %s:%s\n", buf, GST_BUFFER_REFCOUNT (buf), GST_BUFFER_SIZE (buf), GST_DEBUG_PAD_NAME (ident->src)); */
|
/* g_print("pushing buffer %p (refcount %d - buffersize %d) to pad %s:%s\n", buf, GST_BUFFER_REFCOUNT (buf), GST_BUFFER_SIZE (buf), GST_DEBUG_PAD_NAME (ident->src)); */
|
||||||
GST_DEBUG (0, "push %p %" G_GINT64_FORMAT, buf, GST_BUFFER_OFFSET (buf));
|
GST_LOG ( "push %p %" G_GINT64_FORMAT, buf, GST_BUFFER_OFFSET (buf));
|
||||||
gst_pad_push (ident->src, buf);
|
gst_pad_push (ident->src, buf);
|
||||||
} else if (GST_IS_BUFFER (buf)) {
|
} else if (GST_IS_BUFFER (buf)) {
|
||||||
gst_buffer_unref (buf);
|
gst_buffer_unref (buf);
|
||||||
|
@ -272,7 +277,7 @@ gst_spider_identity_request_new_pad (GstElement *element, GstPadTemplate *templ
|
||||||
case GST_PAD_SINK:
|
case GST_PAD_SINK:
|
||||||
if (ident->sink != NULL) break;
|
if (ident->sink != NULL) break;
|
||||||
/* sink */
|
/* sink */
|
||||||
GST_DEBUG(0, "element %s requests new sink pad", GST_ELEMENT_NAME(ident));
|
GST_DEBUG ( "element %s requests new sink pad", GST_ELEMENT_NAME(ident));
|
||||||
ident->sink = gst_pad_new ("sink", GST_PAD_SINK);
|
ident->sink = gst_pad_new ("sink", GST_PAD_SINK);
|
||||||
gst_element_add_pad (GST_ELEMENT (ident), ident->sink);
|
gst_element_add_pad (GST_ELEMENT (ident), ident->sink);
|
||||||
gst_pad_set_link_function (ident->sink, GST_DEBUG_FUNCPTR (gst_spider_identity_link));
|
gst_pad_set_link_function (ident->sink, GST_DEBUG_FUNCPTR (gst_spider_identity_link));
|
||||||
|
@ -282,7 +287,7 @@ gst_spider_identity_request_new_pad (GstElement *element, GstPadTemplate *templ
|
||||||
case GST_PAD_SRC:
|
case GST_PAD_SRC:
|
||||||
/* src */
|
/* src */
|
||||||
if (ident->src != NULL) break;
|
if (ident->src != NULL) break;
|
||||||
GST_DEBUG(0, "element %s requests new src pad", GST_ELEMENT_NAME(ident));
|
GST_DEBUG ( "element %s requests new src pad", GST_ELEMENT_NAME(ident));
|
||||||
ident->src = gst_pad_new ("src", GST_PAD_SRC);
|
ident->src = gst_pad_new ("src", GST_PAD_SRC);
|
||||||
gst_element_add_pad (GST_ELEMENT (ident), ident->src);
|
gst_element_add_pad (GST_ELEMENT (ident), ident->src);
|
||||||
gst_pad_set_link_function (ident->src, GST_DEBUG_FUNCPTR (gst_spider_identity_link));
|
gst_pad_set_link_function (ident->src, GST_DEBUG_FUNCPTR (gst_spider_identity_link));
|
||||||
|
@ -293,7 +298,7 @@ gst_spider_identity_request_new_pad (GstElement *element, GstPadTemplate *templ
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
GST_DEBUG(0, "element %s requested a new pad but none could be created", GST_ELEMENT_NAME(ident));
|
GST_DEBUG ( "element %s requested a new pad but none could be created", GST_ELEMENT_NAME(ident));
|
||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -354,7 +359,7 @@ gst_spider_identity_start_type_finding (GstSpiderIdentity *ident)
|
||||||
gchar *name;*/
|
gchar *name;*/
|
||||||
gboolean restart = FALSE;
|
gboolean restart = FALSE;
|
||||||
|
|
||||||
GST_DEBUG (GST_CAT_AUTOPLUG, "element %s starts typefinding", GST_ELEMENT_NAME(ident));
|
GST_DEBUG ("element %s starts typefinding", GST_ELEMENT_NAME(ident));
|
||||||
if (GST_STATE (GST_ELEMENT_PARENT (ident)) == GST_STATE_PLAYING)
|
if (GST_STATE (GST_ELEMENT_PARENT (ident)) == GST_STATE_PLAYING)
|
||||||
{
|
{
|
||||||
gst_element_set_state (GST_ELEMENT (GST_ELEMENT_PARENT (ident)), GST_STATE_PAUSED);
|
gst_element_set_state (GST_ELEMENT (GST_ELEMENT_PARENT (ident)), GST_STATE_PAUSED);
|
||||||
|
@ -481,9 +486,9 @@ gst_spider_identity_sink_loop_type_finding (GstSpiderIdentity *ident)
|
||||||
GstTypeFactory *factory = GST_TYPE_FACTORY (factories->data);
|
GstTypeFactory *factory = GST_TYPE_FACTORY (factories->data);
|
||||||
GstTypeFindFunc typefindfunc = (GstTypeFindFunc)factory->typefindfunc;
|
GstTypeFindFunc typefindfunc = (GstTypeFindFunc)factory->typefindfunc;
|
||||||
|
|
||||||
GST_DEBUG (GST_CAT_AUTOPLUG_ATTEMPT, "trying typefind function %s", GST_PLUGIN_FEATURE_NAME (factory));
|
GST_DEBUG ("trying typefind function %s", GST_PLUGIN_FEATURE_NAME (factory));
|
||||||
if (typefindfunc && (caps = typefindfunc (buf, factory))) {
|
if (typefindfunc && (caps = typefindfunc (buf, factory))) {
|
||||||
GST_INFO (GST_CAT_AUTOPLUG_ATTEMPT, "typefind function %s found caps", GST_PLUGIN_FEATURE_NAME (factory));
|
GST_INFO ("typefind function %s found caps", GST_PLUGIN_FEATURE_NAME (factory));
|
||||||
if (gst_pad_try_set_caps (ident->src, caps) <= 0) {
|
if (gst_pad_try_set_caps (ident->src, caps) <= 0) {
|
||||||
g_warning ("typefind: found type but peer didn't accept it");
|
g_warning ("typefind: found type but peer didn't accept it");
|
||||||
gst_caps_sink (caps);
|
gst_caps_sink (caps);
|
||||||
|
@ -526,7 +531,7 @@ gst_spider_identity_handle_src_event (GstPad *pad, GstEvent *event)
|
||||||
gboolean res = TRUE;
|
gboolean res = TRUE;
|
||||||
GstSpiderIdentity *ident;
|
GstSpiderIdentity *ident;
|
||||||
|
|
||||||
GST_DEBUG (0, "spider_identity src_event");
|
GST_DEBUG ( "spider_identity src_event");
|
||||||
|
|
||||||
ident = GST_SPIDER_IDENTITY (gst_pad_get_parent (pad));
|
ident = GST_SPIDER_IDENTITY (gst_pad_get_parent (pad));
|
||||||
|
|
||||||
|
|
|
@ -24,14 +24,12 @@
|
||||||
#ifndef __GST_SPIDER_IDENTITY_H__
|
#ifndef __GST_SPIDER_IDENTITY_H__
|
||||||
#define __GST_SPIDER_IDENTITY_H__
|
#define __GST_SPIDER_IDENTITY_H__
|
||||||
|
|
||||||
|
|
||||||
#include <config.h>
|
|
||||||
#include <gst/gst.h>
|
#include <gst/gst.h>
|
||||||
|
|
||||||
G_BEGIN_DECLS
|
G_BEGIN_DECLS
|
||||||
|
|
||||||
GstElementDetails gst_spider_identity_details;
|
extern GstElementDetails gst_spider_identity_details;
|
||||||
|
GST_DEBUG_CATEGORY_EXTERN(gst_spider_identity_debug);
|
||||||
|
|
||||||
#define GST_TYPE_SPIDER_IDENTITY \
|
#define GST_TYPE_SPIDER_IDENTITY \
|
||||||
(gst_spider_identity_get_type())
|
(gst_spider_identity_get_type())
|
||||||
|
|
|
@ -26,6 +26,9 @@
|
||||||
|
|
||||||
#define GST_AUTOPLUG_MAX_COST 999999
|
#define GST_AUTOPLUG_MAX_COST 999999
|
||||||
|
|
||||||
|
GST_DEBUG_CATEGORY_STATIC(debug_category);
|
||||||
|
#define GST_CAT_DEFAULT debug_category
|
||||||
|
|
||||||
typedef guint (*GstAutoplugCostFunction) (gpointer src, gpointer dest, gpointer data);
|
typedef guint (*GstAutoplugCostFunction) (gpointer src, gpointer dest, gpointer data);
|
||||||
typedef const GList* (*GstAutoplugListFunction) (gpointer data);
|
typedef const GList* (*GstAutoplugListFunction) (gpointer data);
|
||||||
|
|
||||||
|
@ -86,6 +89,8 @@ plugin_init (GModule *module, GstPlugin *plugin)
|
||||||
{
|
{
|
||||||
GstAutoplugFactory *factory;
|
GstAutoplugFactory *factory;
|
||||||
|
|
||||||
|
GST_DEBUG_CATEGORY_INIT (debug_category, "STATIC_AUTOPLUG", 0, "static autoplugger element");
|
||||||
|
|
||||||
gst_plugin_set_longname (plugin, "A static autoplugger");
|
gst_plugin_set_longname (plugin, "A static autoplugger");
|
||||||
|
|
||||||
factory = gst_autoplug_factory_new ("static",
|
factory = gst_autoplug_factory_new ("static",
|
||||||
|
@ -124,8 +129,7 @@ gst_autoplug_can_match (GstElementFactory *src, GstElementFactory *dest)
|
||||||
desttemp->direction == GST_PAD_SINK) {
|
desttemp->direction == GST_PAD_SINK) {
|
||||||
if (gst_caps_is_always_compatible (gst_pad_template_get_caps (srctemp),
|
if (gst_caps_is_always_compatible (gst_pad_template_get_caps (srctemp),
|
||||||
gst_pad_template_get_caps (desttemp))) {
|
gst_pad_template_get_caps (desttemp))) {
|
||||||
GST_DEBUG (GST_CAT_AUTOPLUG_ATTEMPT,
|
GST_DEBUG ("factory \"%s\" can link with factory \"%s\"\n", GST_OBJECT_NAME (src),
|
||||||
"factory \"%s\" can link with factory \"%s\"\n", GST_OBJECT_NAME (src),
|
|
||||||
GST_OBJECT_NAME (dest));
|
GST_OBJECT_NAME (dest));
|
||||||
return TRUE;
|
return TRUE;
|
||||||
}
|
}
|
||||||
|
@ -135,8 +139,7 @@ gst_autoplug_can_match (GstElementFactory *src, GstElementFactory *dest)
|
||||||
}
|
}
|
||||||
srctemps = g_list_next (srctemps);
|
srctemps = g_list_next (srctemps);
|
||||||
}
|
}
|
||||||
GST_DEBUG (GST_CAT_AUTOPLUG_ATTEMPT,
|
GST_DEBUG ("factory \"%s\" cannot link with factory \"%s\"\n", GST_OBJECT_NAME (src),
|
||||||
"factory \"%s\" cannot link with factory \"%s\"\n", GST_OBJECT_NAME (src),
|
|
||||||
GST_OBJECT_NAME (dest));
|
GST_OBJECT_NAME (dest));
|
||||||
return FALSE;
|
return FALSE;
|
||||||
}
|
}
|
||||||
|
@ -147,7 +150,7 @@ gst_autoplug_pads_autoplug_func (GstElement *src, GstPad *pad, GstElement *sink)
|
||||||
const GList *sinkpads;
|
const GList *sinkpads;
|
||||||
gboolean linked = FALSE;
|
gboolean linked = FALSE;
|
||||||
|
|
||||||
GST_DEBUG (0,"gstpipeline: autoplug pad link function for \"%s\" to \"%s\"",
|
GST_DEBUG ("gstpipeline: autoplug pad link function for \"%s\" to \"%s\"",
|
||||||
GST_ELEMENT_NAME(src), GST_ELEMENT_NAME(sink));
|
GST_ELEMENT_NAME(src), GST_ELEMENT_NAME(sink));
|
||||||
|
|
||||||
sinkpads = gst_element_get_pad_list(sink);
|
sinkpads = gst_element_get_pad_list(sink);
|
||||||
|
@ -160,22 +163,22 @@ gst_autoplug_pads_autoplug_func (GstElement *src, GstPad *pad, GstElement *sink)
|
||||||
{
|
{
|
||||||
if (gst_caps_is_always_compatible (gst_pad_get_caps(pad), gst_pad_get_caps(sinkpad))) {
|
if (gst_caps_is_always_compatible (gst_pad_get_caps(pad), gst_pad_get_caps(sinkpad))) {
|
||||||
gst_pad_link(pad, sinkpad);
|
gst_pad_link(pad, sinkpad);
|
||||||
GST_DEBUG (0,"gstpipeline: autolink pad \"%s\" in element %s <-> ", GST_PAD_NAME (pad),
|
GST_DEBUG ("gstpipeline: autolink pad \"%s\" in element %s <-> ", GST_PAD_NAME (pad),
|
||||||
GST_ELEMENT_NAME(src));
|
GST_ELEMENT_NAME(src));
|
||||||
GST_DEBUG (0,"pad \"%s\" in element %s", GST_PAD_NAME (sinkpad),
|
GST_DEBUG ("pad \"%s\" in element %s", GST_PAD_NAME (sinkpad),
|
||||||
GST_ELEMENT_NAME(sink));
|
GST_ELEMENT_NAME(sink));
|
||||||
linked = TRUE;
|
linked = TRUE;
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
GST_DEBUG (0,"pads incompatible %s, %s", GST_PAD_NAME (pad), GST_PAD_NAME (sinkpad));
|
GST_DEBUG ("pads incompatible %s, %s", GST_PAD_NAME (pad), GST_PAD_NAME (sinkpad));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
sinkpads = g_list_next(sinkpads);
|
sinkpads = g_list_next(sinkpads);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!linked) {
|
if (!linked) {
|
||||||
GST_DEBUG (0,"gstpipeline: no path to sinks for type");
|
GST_DEBUG ("gstpipeline: no path to sinks for type");
|
||||||
}
|
}
|
||||||
return linked;
|
return linked;
|
||||||
}
|
}
|
||||||
|
@ -192,7 +195,7 @@ autoplug_dynamic_pad (GstElement *element, GstPad *pad, gpointer data)
|
||||||
dynamic_pad_struct *info = (dynamic_pad_struct *)data;
|
dynamic_pad_struct *info = (dynamic_pad_struct *)data;
|
||||||
const GList *pads = gst_element_get_pad_list (element);
|
const GList *pads = gst_element_get_pad_list (element);
|
||||||
|
|
||||||
GST_DEBUG (0,"attempting to dynamically create a ghostpad for %s=%s", GST_ELEMENT_NAME (element),
|
GST_DEBUG ("attempting to dynamically create a ghostpad for %s=%s", GST_ELEMENT_NAME (element),
|
||||||
GST_PAD_NAME (pad));
|
GST_PAD_NAME (pad));
|
||||||
|
|
||||||
while (pads) {
|
while (pads) {
|
||||||
|
@ -207,7 +210,7 @@ autoplug_dynamic_pad (GstElement *element, GstPad *pad, gpointer data)
|
||||||
gst_element_add_ghost_pad (info->result, pad, name);
|
gst_element_add_ghost_pad (info->result, pad, name);
|
||||||
g_free (name);
|
g_free (name);
|
||||||
|
|
||||||
GST_DEBUG (0,"gstpipeline: new dynamic pad %s", GST_PAD_NAME (pad));
|
GST_DEBUG ("gstpipeline: new dynamic pad %s", GST_PAD_NAME (pad));
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -231,7 +234,7 @@ gst_autoplug_pads_autoplug (GstElement *src, GstElement *sink)
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!linked) {
|
if (!linked) {
|
||||||
GST_DEBUG (0,"gstpipeline: delaying pad links for \"%s\" to \"%s\"",
|
GST_DEBUG ("gstpipeline: delaying pad links for \"%s\" to \"%s\"",
|
||||||
GST_ELEMENT_NAME(src), GST_ELEMENT_NAME(sink));
|
GST_ELEMENT_NAME(src), GST_ELEMENT_NAME(sink));
|
||||||
g_signal_connect (G_OBJECT(src), "new_pad",
|
g_signal_connect (G_OBJECT(src), "new_pad",
|
||||||
G_CALLBACK (gst_autoplug_pads_autoplug_func), sink);
|
G_CALLBACK (gst_autoplug_pads_autoplug_func), sink);
|
||||||
|
@ -302,7 +305,7 @@ gst_static_autoplug_to_caps (GstAutoplug *autoplug, GstCaps *srccaps, GstCaps *s
|
||||||
|
|
||||||
caps.sink = capslist;
|
caps.sink = capslist;
|
||||||
|
|
||||||
GST_INFO (GST_CAT_AUTOPLUG_ATTEMPT,"autoplugging two caps structures");
|
GST_INFO ("autoplugging two caps structures");
|
||||||
|
|
||||||
elements = gst_autoplug_func (caps.src, caps.sink,
|
elements = gst_autoplug_func (caps.src, caps.sink,
|
||||||
gst_autoplug_element_factory_get_list,
|
gst_autoplug_element_factory_get_list,
|
||||||
|
@ -371,7 +374,7 @@ gst_static_autoplug_to_caps (GstAutoplug *autoplug, GstCaps *srccaps, GstCaps *s
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
GST_DEBUG (0,"common factory \"%s\"", GST_OBJECT_NAME (factory));
|
GST_DEBUG ("common factory \"%s\"", GST_OBJECT_NAME (factory));
|
||||||
|
|
||||||
/* it is likely that the plugin is not loaded yet. thus when it loads it
|
/* it is likely that the plugin is not loaded yet. thus when it loads it
|
||||||
* will replace the elementfactory that gst built from the cache, and the
|
* will replace the elementfactory that gst built from the cache, and the
|
||||||
|
@ -433,10 +436,10 @@ differ:
|
||||||
|
|
||||||
factory = (GstElementFactory *)(factories[i]->data);
|
factory = (GstElementFactory *)(factories[i]->data);
|
||||||
|
|
||||||
GST_DEBUG (0,"factory \"%s\"", GST_OBJECT_NAME (factory));
|
GST_DEBUG ("factory \"%s\"", GST_OBJECT_NAME (factory));
|
||||||
element = gst_element_factory_create(factory, GST_OBJECT_NAME (factory));
|
element = gst_element_factory_create(factory, GST_OBJECT_NAME (factory));
|
||||||
|
|
||||||
GST_DEBUG (0,"adding element %s", GST_ELEMENT_NAME (element));
|
GST_DEBUG ("adding element %s", GST_ELEMENT_NAME (element));
|
||||||
gst_bin_add(GST_BIN(thebin), element);
|
gst_bin_add(GST_BIN(thebin), element);
|
||||||
gst_autoplug_signal_new_object (GST_AUTOPLUG (autoplug), GST_OBJECT (element));
|
gst_autoplug_signal_new_object (GST_AUTOPLUG (autoplug), GST_OBJECT (element));
|
||||||
|
|
||||||
|
@ -457,7 +460,7 @@ differ:
|
||||||
gboolean have_pad = FALSE;
|
gboolean have_pad = FALSE;
|
||||||
endcaps = g_list_next (endcaps);
|
endcaps = g_list_next (endcaps);
|
||||||
|
|
||||||
GST_DEBUG (0,"attempting to create a ghostpad for %s", GST_ELEMENT_NAME (thesrcelement));
|
GST_DEBUG ("attempting to create a ghostpad for %s", GST_ELEMENT_NAME (thesrcelement));
|
||||||
|
|
||||||
while (pads) {
|
while (pads) {
|
||||||
GstPad *pad = GST_PAD (pads->data);
|
GstPad *pad = GST_PAD (pads->data);
|
||||||
|
@ -482,7 +485,7 @@ differ:
|
||||||
data->endcap = endcap;
|
data->endcap = endcap;
|
||||||
data->i = i;
|
data->i = i;
|
||||||
|
|
||||||
GST_DEBUG (0,"delaying the creation of a ghostpad for %s", GST_ELEMENT_NAME (thesrcelement));
|
GST_DEBUG ("delaying the creation of a ghostpad for %s", GST_ELEMENT_NAME (thesrcelement));
|
||||||
g_signal_connect (G_OBJECT (thesrcelement), "new_pad",
|
g_signal_connect (G_OBJECT (thesrcelement), "new_pad",
|
||||||
G_CALLBACK (autoplug_dynamic_pad), data);
|
G_CALLBACK (autoplug_dynamic_pad), data);
|
||||||
}
|
}
|
||||||
|
@ -525,7 +528,7 @@ construct_path (gst_autoplug_node *rgnNodes, gpointer factory)
|
||||||
|
|
||||||
current = rgnNodes[find_factory(rgnNodes, factory)].iPrev;
|
current = rgnNodes[find_factory(rgnNodes, factory)].iPrev;
|
||||||
|
|
||||||
GST_INFO (GST_CAT_AUTOPLUG_ATTEMPT,"factories found in autoplugging (reversed order)");
|
GST_INFO ("factories found in autoplugging (reversed order)");
|
||||||
|
|
||||||
while (current != NULL)
|
while (current != NULL)
|
||||||
{
|
{
|
||||||
|
@ -534,7 +537,7 @@ construct_path (gst_autoplug_node *rgnNodes, gpointer factory)
|
||||||
next = rgnNodes[find_factory(rgnNodes, current)].iPrev;
|
next = rgnNodes[find_factory(rgnNodes, current)].iPrev;
|
||||||
if (next) {
|
if (next) {
|
||||||
factories = g_list_prepend (factories, current);
|
factories = g_list_prepend (factories, current);
|
||||||
GST_INFO (GST_CAT_AUTOPLUG_ATTEMPT,"factory: \"%s\"", GST_OBJECT_NAME (current));
|
GST_INFO ("factory: \"%s\"", GST_OBJECT_NAME (current));
|
||||||
}
|
}
|
||||||
current = next;
|
current = next;
|
||||||
}
|
}
|
||||||
|
@ -642,4 +645,3 @@ gst_autoplug_func (gpointer src, gpointer sink,
|
||||||
|
|
||||||
return construct_path (rgnNodes, sink);
|
return construct_path (rgnNodes, sink);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -26,6 +26,9 @@
|
||||||
|
|
||||||
#define GST_AUTOPLUG_MAX_COST 999999
|
#define GST_AUTOPLUG_MAX_COST 999999
|
||||||
|
|
||||||
|
GST_DEBUG_CATEGORY_STATIC(debug_category);
|
||||||
|
#define GST_CAT_DEFAULT debug_category
|
||||||
|
|
||||||
typedef guint (*GstAutoplugCostFunction) (gpointer src, gpointer dest, gpointer data);
|
typedef guint (*GstAutoplugCostFunction) (gpointer src, gpointer dest, gpointer data);
|
||||||
typedef GList* (*GstAutoplugListFunction) (gpointer data);
|
typedef GList* (*GstAutoplugListFunction) (gpointer data);
|
||||||
|
|
||||||
|
@ -88,6 +91,8 @@ plugin_init (GModule *module, GstPlugin *plugin)
|
||||||
|
|
||||||
gst_plugin_set_longname (plugin, "A static autoplugger");
|
gst_plugin_set_longname (plugin, "A static autoplugger");
|
||||||
|
|
||||||
|
GST_DEBUG_CATEGORY_INIT (debug_category, "STATIC_AUTOPLUG", 0, "static autoplug render element");
|
||||||
|
|
||||||
factory = gst_autoplug_factory_new ("staticrender",
|
factory = gst_autoplug_factory_new ("staticrender",
|
||||||
"A static autoplugger, it constructs the complete element before running it",
|
"A static autoplugger, it constructs the complete element before running it",
|
||||||
gst_static_autoplug_render_get_type ());
|
gst_static_autoplug_render_get_type ());
|
||||||
|
@ -153,8 +158,7 @@ gst_autoplug_can_match (GstElementFactory *src, GstElementFactory *dest)
|
||||||
|
|
||||||
if (desttemp->direction == GST_PAD_SINK && desttemp->presence != GST_PAD_REQUEST) {
|
if (desttemp->direction == GST_PAD_SINK && desttemp->presence != GST_PAD_REQUEST) {
|
||||||
if (gst_caps_is_always_compatible (GST_PAD_TEMPLATE_CAPS (srctemp), GST_PAD_TEMPLATE_CAPS (desttemp))) {
|
if (gst_caps_is_always_compatible (GST_PAD_TEMPLATE_CAPS (srctemp), GST_PAD_TEMPLATE_CAPS (desttemp))) {
|
||||||
GST_DEBUG (GST_CAT_AUTOPLUG_ATTEMPT,
|
GST_DEBUG ("factory \"%s\" can link with factory \"%s\"",
|
||||||
"factory \"%s\" can link with factory \"%s\"",
|
|
||||||
GST_OBJECT_NAME (src), GST_OBJECT_NAME (dest));
|
GST_OBJECT_NAME (src), GST_OBJECT_NAME (dest));
|
||||||
return TRUE;
|
return TRUE;
|
||||||
}
|
}
|
||||||
|
@ -162,8 +166,7 @@ gst_autoplug_can_match (GstElementFactory *src, GstElementFactory *dest)
|
||||||
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
GST_DEBUG (GST_CAT_AUTOPLUG_ATTEMPT,
|
GST_DEBUG ("factory \"%s\" cannot link with factory \"%s\"",
|
||||||
"factory \"%s\" cannot link with factory \"%s\"",
|
|
||||||
GST_OBJECT_NAME (src), GST_OBJECT_NAME (dest));
|
GST_OBJECT_NAME (src), GST_OBJECT_NAME (dest));
|
||||||
return FALSE;
|
return FALSE;
|
||||||
}
|
}
|
||||||
|
@ -175,7 +178,7 @@ gst_autoplug_pads_autoplug_func (GstElement *src, GstPad *pad, GstElement *sink)
|
||||||
gboolean linked = FALSE;
|
gboolean linked = FALSE;
|
||||||
GstElementState state = GST_STATE (gst_element_get_parent (src));
|
GstElementState state = GST_STATE (gst_element_get_parent (src));
|
||||||
|
|
||||||
GST_DEBUG (0,"gstpipeline: autoplug pad link function for %s %s:%s to \"%s\"",
|
GST_DEBUG ("gstpipeline: autoplug pad link function for %s %s:%s to \"%s\"",
|
||||||
GST_ELEMENT_NAME (src), GST_DEBUG_PAD_NAME(pad), GST_ELEMENT_NAME(sink));
|
GST_ELEMENT_NAME (src), GST_DEBUG_PAD_NAME(pad), GST_ELEMENT_NAME(sink));
|
||||||
|
|
||||||
if (state == GST_STATE_PLAYING)
|
if (state == GST_STATE_PLAYING)
|
||||||
|
@ -194,7 +197,7 @@ gst_autoplug_pads_autoplug_func (GstElement *src, GstPad *pad, GstElement *sink)
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
GST_DEBUG (0,"pads incompatible %s, %s", GST_PAD_NAME (pad), GST_PAD_NAME (sinkpad));
|
GST_DEBUG ("pads incompatible %s, %s", GST_PAD_NAME (pad), GST_PAD_NAME (sinkpad));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
sinkpads = g_list_next(sinkpads);
|
sinkpads = g_list_next(sinkpads);
|
||||||
|
@ -204,7 +207,7 @@ gst_autoplug_pads_autoplug_func (GstElement *src, GstPad *pad, GstElement *sink)
|
||||||
gst_element_set_state (GST_ELEMENT (gst_element_get_parent (src)), GST_STATE_PLAYING);
|
gst_element_set_state (GST_ELEMENT (gst_element_get_parent (src)), GST_STATE_PLAYING);
|
||||||
|
|
||||||
if (!linked) {
|
if (!linked) {
|
||||||
GST_DEBUG (0,"gstpipeline: no path to sinks for type");
|
GST_DEBUG ("gstpipeline: no path to sinks for type");
|
||||||
}
|
}
|
||||||
return linked;
|
return linked;
|
||||||
}
|
}
|
||||||
|
@ -230,7 +233,7 @@ gst_autoplug_pads_autoplug (GstElement *src, GstElement *sink)
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!linked) {
|
if (!linked) {
|
||||||
GST_DEBUG (0,"gstpipeline: delaying pad links for \"%s\" to \"%s\"",
|
GST_DEBUG ("gstpipeline: delaying pad links for \"%s\" to \"%s\"",
|
||||||
GST_ELEMENT_NAME(src), GST_ELEMENT_NAME(sink));
|
GST_ELEMENT_NAME(src), GST_ELEMENT_NAME(sink));
|
||||||
g_signal_connect (G_OBJECT(src),"new_pad",
|
g_signal_connect (G_OBJECT(src),"new_pad",
|
||||||
G_CALLBACK (gst_autoplug_pads_autoplug_func), sink);
|
G_CALLBACK (gst_autoplug_pads_autoplug_func), sink);
|
||||||
|
@ -257,7 +260,6 @@ gst_autoplug_caps_find_cost (gpointer src, gpointer dest, gpointer data)
|
||||||
|
|
||||||
if (IS_CAPS (src) && IS_CAPS (dest)) {
|
if (IS_CAPS (src) && IS_CAPS (dest)) {
|
||||||
res = gst_caps_is_always_compatible ((GstCaps *)src, (GstCaps *)dest);
|
res = gst_caps_is_always_compatible ((GstCaps *)src, (GstCaps *)dest);
|
||||||
/*GST_INFO (GST_CAT_AUTOPLUG_ATTEMPT,"caps %d to caps %d %d", ((GstCaps *)src)->id, ((GstCaps *)dest)->id, res); */
|
|
||||||
}
|
}
|
||||||
else if (IS_CAPS (src)) {
|
else if (IS_CAPS (src)) {
|
||||||
GstPadTemplate *templ;
|
GstPadTemplate *templ;
|
||||||
|
@ -269,7 +271,6 @@ gst_autoplug_caps_find_cost (gpointer src, gpointer dest, gpointer data)
|
||||||
else
|
else
|
||||||
res = FALSE;
|
res = FALSE;
|
||||||
|
|
||||||
/*GST_INFO (GST_CAT_AUTOPLUG_ATTEMPT,"factory %s to src caps %d %d", ((GstElementFactory *)dest)->name, ((GstCaps *)src)->id, res);*/
|
|
||||||
}
|
}
|
||||||
else if (IS_CAPS (dest)) {
|
else if (IS_CAPS (dest)) {
|
||||||
GstPadTemplate *templ;
|
GstPadTemplate *templ;
|
||||||
|
@ -280,12 +281,10 @@ gst_autoplug_caps_find_cost (gpointer src, gpointer dest, gpointer data)
|
||||||
res = TRUE;
|
res = TRUE;
|
||||||
else
|
else
|
||||||
res = FALSE;
|
res = FALSE;
|
||||||
/*GST_INFO (GST_CAT_AUTOPLUG_ATTEMPT,"factory %s to sink caps %d %d", ((GstElementFactory *)src)->name, ((GstCaps *)dest)->id, res);*/
|
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
res = gst_autoplug_can_match ((GstElementFactory *)src, (GstElementFactory *)dest);
|
res = gst_autoplug_can_match ((GstElementFactory *)src, (GstElementFactory *)dest);
|
||||||
GST_INFO (GST_CAT_AUTOPLUG_ATTEMPT,"factory %s to factory %s %d",
|
GST_INFO ("factory %s to factory %s %d", GST_OBJECT_NAME (src), GST_OBJECT_NAME (dest), res);
|
||||||
GST_OBJECT_NAME (src), GST_OBJECT_NAME (dest), res);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
if (res)
|
if (res)
|
||||||
|
@ -328,7 +327,7 @@ gst_static_autoplug_to_render (GstAutoplug *autoplug, GstCaps *srccaps, GstEleme
|
||||||
else
|
else
|
||||||
goto next;
|
goto next;
|
||||||
|
|
||||||
GST_INFO (GST_CAT_AUTOPLUG_ATTEMPT,"autoplugging two caps structures");
|
GST_INFO ("autoplugging two caps structures");
|
||||||
|
|
||||||
elements = gst_autoplug_func (caps.src, caps.sink,
|
elements = gst_autoplug_func (caps.src, caps.sink,
|
||||||
gst_autoplug_element_factory_get_list,
|
gst_autoplug_element_factory_get_list,
|
||||||
|
@ -396,7 +395,7 @@ next:
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
GST_DEBUG (0,"common factory \"%s\"", GST_OBJECT_NAME (factory));
|
GST_DEBUG ("common factory \"%s\"", GST_OBJECT_NAME (factory));
|
||||||
|
|
||||||
element = gst_element_factory_create (factory, g_strdup (GST_OBJECT_NAME (factory)));
|
element = gst_element_factory_create (factory, g_strdup (GST_OBJECT_NAME (factory)));
|
||||||
gst_bin_add (GST_BIN(result), element);
|
gst_bin_add (GST_BIN(result), element);
|
||||||
|
@ -456,7 +455,7 @@ differ:
|
||||||
if (factories[i]) {
|
if (factories[i]) {
|
||||||
factory = (GstElementFactory *)(factories[i]->data);
|
factory = (GstElementFactory *)(factories[i]->data);
|
||||||
|
|
||||||
GST_DEBUG (0,"factory \"%s\"", GST_OBJECT_NAME (factory));
|
GST_DEBUG ("factory \"%s\"", GST_OBJECT_NAME (factory));
|
||||||
element = gst_element_factory_create(factory, g_strdup (GST_OBJECT_NAME (factory)));
|
element = gst_element_factory_create(factory, g_strdup (GST_OBJECT_NAME (factory)));
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
|
@ -472,11 +471,11 @@ differ:
|
||||||
|
|
||||||
use_thread = FALSE;
|
use_thread = FALSE;
|
||||||
|
|
||||||
GST_DEBUG (0,"sugest new thread for \"%s\" %08x", GST_ELEMENT_NAME (element), GST_FLAGS(element));
|
GST_DEBUG ("sugest new thread for \"%s\" %08x", GST_ELEMENT_NAME (element), GST_FLAGS(element));
|
||||||
|
|
||||||
/* create a new queue and add to the previous bin */
|
/* create a new queue and add to the previous bin */
|
||||||
queue = gst_element_factory_make("queue", g_strconcat("queue_", GST_ELEMENT_NAME(element), NULL));
|
queue = gst_element_factory_make("queue", g_strconcat("queue_", GST_ELEMENT_NAME(element), NULL));
|
||||||
GST_DEBUG (0,"adding element \"%s\"", GST_ELEMENT_NAME (element));
|
GST_DEBUG ("adding element \"%s\"", GST_ELEMENT_NAME (element));
|
||||||
|
|
||||||
/* this will be the new bin for all following elements */
|
/* this will be the new bin for all following elements */
|
||||||
thebin = gst_element_factory_make("thread", g_strconcat("thread_", GST_ELEMENT_NAME(element), NULL));
|
thebin = gst_element_factory_make("thread", g_strconcat("thread_", GST_ELEMENT_NAME(element), NULL));
|
||||||
|
@ -488,17 +487,17 @@ differ:
|
||||||
|
|
||||||
gst_autoplug_pads_autoplug(thesrcelement, queue);
|
gst_autoplug_pads_autoplug(thesrcelement, queue);
|
||||||
|
|
||||||
GST_DEBUG (0,"adding element %s", GST_ELEMENT_NAME (element));
|
GST_DEBUG ("adding element %s", GST_ELEMENT_NAME (element));
|
||||||
gst_bin_add(GST_BIN(thebin), element);
|
gst_bin_add(GST_BIN(thebin), element);
|
||||||
gst_autoplug_signal_new_object (GST_AUTOPLUG (autoplug), GST_OBJECT (element));
|
gst_autoplug_signal_new_object (GST_AUTOPLUG (autoplug), GST_OBJECT (element));
|
||||||
GST_DEBUG (0,"adding element %s", GST_ELEMENT_NAME (thebin));
|
GST_DEBUG ("adding element %s", GST_ELEMENT_NAME (thebin));
|
||||||
gst_bin_add(GST_BIN(current_bin), thebin);
|
gst_bin_add(GST_BIN(current_bin), thebin);
|
||||||
gst_autoplug_signal_new_object (GST_AUTOPLUG (autoplug), GST_OBJECT (thebin));
|
gst_autoplug_signal_new_object (GST_AUTOPLUG (autoplug), GST_OBJECT (thebin));
|
||||||
thesrcelement = queue;
|
thesrcelement = queue;
|
||||||
}
|
}
|
||||||
/* no thread needed, easy case */
|
/* no thread needed, easy case */
|
||||||
else {
|
else {
|
||||||
GST_DEBUG (0,"adding element %s", GST_ELEMENT_NAME (element));
|
GST_DEBUG ("adding element %s", GST_ELEMENT_NAME (element));
|
||||||
gst_bin_add(GST_BIN(thebin), element);
|
gst_bin_add(GST_BIN(thebin), element);
|
||||||
gst_autoplug_signal_new_object (GST_AUTOPLUG (autoplug), GST_OBJECT (element));
|
gst_autoplug_signal_new_object (GST_AUTOPLUG (autoplug), GST_OBJECT (element));
|
||||||
}
|
}
|
||||||
|
@ -547,7 +546,7 @@ construct_path (gst_autoplug_node *rgnNodes, gpointer factory)
|
||||||
|
|
||||||
current = rgnNodes[find_factory(rgnNodes, factory)].iPrev;
|
current = rgnNodes[find_factory(rgnNodes, factory)].iPrev;
|
||||||
|
|
||||||
GST_INFO (GST_CAT_AUTOPLUG_ATTEMPT,"factories found in autoplugging (reversed order)");
|
GST_INFO ("factories found in autoplugging (reversed order)");
|
||||||
|
|
||||||
while (current != NULL)
|
while (current != NULL)
|
||||||
{
|
{
|
||||||
|
@ -556,7 +555,7 @@ construct_path (gst_autoplug_node *rgnNodes, gpointer factory)
|
||||||
next = rgnNodes[find_factory(rgnNodes, current)].iPrev;
|
next = rgnNodes[find_factory(rgnNodes, current)].iPrev;
|
||||||
if (next) {
|
if (next) {
|
||||||
factories = g_list_prepend (factories, current);
|
factories = g_list_prepend (factories, current);
|
||||||
GST_INFO (GST_CAT_AUTOPLUG_ATTEMPT,"factory: \"%s\"", GST_OBJECT_NAME (current));
|
GST_INFO ("factory: \"%s\"", GST_OBJECT_NAME (current));
|
||||||
}
|
}
|
||||||
current = next;
|
current = next;
|
||||||
}
|
}
|
||||||
|
@ -664,4 +663,3 @@ gst_autoplug_func (gpointer src, gpointer sink,
|
||||||
|
|
||||||
return construct_path (rgnNodes, sink);
|
return construct_path (rgnNodes, sink);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -34,7 +34,7 @@
|
||||||
|
|
||||||
#include "cothreads.h"
|
#include "cothreads.h"
|
||||||
#include "gstarch.h"
|
#include "gstarch.h"
|
||||||
#include "gstlog.h"
|
#include "gstinfo.h"
|
||||||
#include "gstutils.h"
|
#include "gstutils.h"
|
||||||
|
|
||||||
#ifdef HAVE_UCONTEXT_H
|
#ifdef HAVE_UCONTEXT_H
|
||||||
|
@ -113,7 +113,7 @@ cothread_context_init (void)
|
||||||
* just return it */
|
* just return it */
|
||||||
ctx = g_static_private_get (&_cothread_ctx_key);
|
ctx = g_static_private_get (&_cothread_ctx_key);
|
||||||
if (ctx) {
|
if (ctx) {
|
||||||
GST_INFO (GST_CAT_COTHREADS,
|
GST_CAT_INFO (GST_CAT_COTHREADS,
|
||||||
"returning private _cothread_ctx_key %p", ctx);
|
"returning private _cothread_ctx_key %p", ctx);
|
||||||
return ctx;
|
return ctx;
|
||||||
}
|
}
|
||||||
|
@ -129,10 +129,10 @@ cothread_context_init (void)
|
||||||
ctx->data = g_hash_table_new (g_str_hash, g_str_equal);
|
ctx->data = g_hash_table_new (g_str_hash, g_str_equal);
|
||||||
ctx->thread = g_thread_self();
|
ctx->thread = g_thread_self();
|
||||||
|
|
||||||
GST_INFO (GST_CAT_COTHREADS, "initializing cothreads");
|
GST_CAT_INFO (GST_CAT_COTHREADS, "initializing cothreads");
|
||||||
|
|
||||||
/* set this thread's context pointer */
|
/* set this thread's context pointer */
|
||||||
GST_INFO (GST_CAT_COTHREADS, "setting private _cothread_ctx_key to %p in thread %p",
|
GST_CAT_INFO (GST_CAT_COTHREADS, "setting private _cothread_ctx_key to %p in thread %p",
|
||||||
ctx,g_thread_self());
|
ctx,g_thread_self());
|
||||||
g_static_private_set (&_cothread_ctx_key, ctx, NULL);
|
g_static_private_set (&_cothread_ctx_key, ctx, NULL);
|
||||||
|
|
||||||
|
@ -149,7 +149,7 @@ cothread_context_init (void)
|
||||||
/* FIXME: an assumption is made that the stack segment is STACK_SIZE
|
/* FIXME: an assumption is made that the stack segment is STACK_SIZE
|
||||||
* aligned. */
|
* aligned. */
|
||||||
ctx->stack_top = ((gulong) current_stack_frame | (STACK_SIZE - 1)) + 1;
|
ctx->stack_top = ((gulong) current_stack_frame | (STACK_SIZE - 1)) + 1;
|
||||||
GST_DEBUG (GST_CAT_COTHREADS, "stack top is 0x%08lx", ctx->stack_top);
|
GST_CAT_DEBUG (GST_CAT_COTHREADS, "stack top is 0x%08lx", ctx->stack_top);
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* initialize the 0th cothread
|
* initialize the 0th cothread
|
||||||
|
@ -164,7 +164,7 @@ cothread_context_init (void)
|
||||||
ctx->cothreads[0]->flags = COTHREAD_STARTED;
|
ctx->cothreads[0]->flags = COTHREAD_STARTED;
|
||||||
ctx->cothreads[0]->sp = (void *) current_stack_frame;
|
ctx->cothreads[0]->sp = (void *) current_stack_frame;
|
||||||
|
|
||||||
GST_INFO (GST_CAT_COTHREADS, "0th cothread is %p at sp:%p",
|
GST_CAT_INFO (GST_CAT_COTHREADS, "0th cothread is %p at sp:%p",
|
||||||
ctx->cothreads[0], ctx->cothreads[0]->sp);
|
ctx->cothreads[0], ctx->cothreads[0]->sp);
|
||||||
|
|
||||||
return ctx;
|
return ctx;
|
||||||
|
@ -185,7 +185,7 @@ cothread_context_free (cothread_context *ctx)
|
||||||
g_assert (ctx->thread == g_thread_self());
|
g_assert (ctx->thread == g_thread_self());
|
||||||
g_assert (ctx->current == 0);
|
g_assert (ctx->current == 0);
|
||||||
|
|
||||||
GST_INFO (GST_CAT_COTHREADS, "free cothread context");
|
GST_CAT_INFO (GST_CAT_COTHREADS, "free cothread context");
|
||||||
|
|
||||||
for (i = 1; i < COTHREAD_MAXTHREADS; i++) {
|
for (i = 1; i < COTHREAD_MAXTHREADS; i++) {
|
||||||
if (ctx->cothreads[i]) {
|
if (ctx->cothreads[i]) {
|
||||||
|
@ -198,7 +198,7 @@ cothread_context_free (cothread_context *ctx)
|
||||||
}
|
}
|
||||||
g_hash_table_destroy (ctx->data);
|
g_hash_table_destroy (ctx->data);
|
||||||
/* make sure we free the private key for cothread context */
|
/* make sure we free the private key for cothread context */
|
||||||
GST_INFO (GST_CAT_COTHREADS, "setting private _cothread_ctx_key to NULL in thread %p",
|
GST_CAT_INFO (GST_CAT_COTHREADS, "setting private _cothread_ctx_key to NULL in thread %p",
|
||||||
g_thread_self());
|
g_thread_self());
|
||||||
g_static_private_set (&_cothread_ctx_key, NULL, NULL);
|
g_static_private_set (&_cothread_ctx_key, NULL, NULL);
|
||||||
g_free (ctx);
|
g_free (ctx);
|
||||||
|
@ -222,7 +222,7 @@ cothread_create (cothread_context *ctx)
|
||||||
|
|
||||||
g_return_val_if_fail (ctx != NULL, NULL);
|
g_return_val_if_fail (ctx != NULL, NULL);
|
||||||
|
|
||||||
GST_DEBUG (GST_CAT_COTHREADS, "manager sef %p, cothread self %p",
|
GST_CAT_DEBUG (GST_CAT_COTHREADS, "manager sef %p, cothread self %p",
|
||||||
ctx->thread, g_thread_self());
|
ctx->thread, g_thread_self());
|
||||||
|
|
||||||
if (ctx->ncothreads == COTHREAD_MAXTHREADS) {
|
if (ctx->ncothreads == COTHREAD_MAXTHREADS) {
|
||||||
|
@ -241,21 +241,21 @@ cothread_create (cothread_context *ctx)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
GST_DEBUG (GST_CAT_COTHREADS, "Found free cothread slot %d", slot);
|
GST_CAT_DEBUG (GST_CAT_COTHREADS, "Found free cothread slot %d", slot);
|
||||||
|
|
||||||
/* cothread stack space of the thread is mapped in reverse, with cothread 0
|
/* cothread stack space of the thread is mapped in reverse, with cothread 0
|
||||||
* stack space at the top */
|
* stack space at the top */
|
||||||
cothread = (cothread_state *) (ctx->stack_top - (slot + 1) * COTHREAD_STACKSIZE);
|
cothread = (cothread_state *) (ctx->stack_top - (slot + 1) * COTHREAD_STACKSIZE);
|
||||||
GST_DEBUG (GST_CAT_COTHREADS, "cothread pointer is %p", cothread);
|
GST_CAT_DEBUG (GST_CAT_COTHREADS, "cothread pointer is %p", cothread);
|
||||||
|
|
||||||
#if 0
|
#if 0
|
||||||
/* This tests to see whether or not we can grow down the stack */
|
/* This tests to see whether or not we can grow down the stack */
|
||||||
{
|
{
|
||||||
unsigned long ptr;
|
unsigned long ptr;
|
||||||
for(ptr=ctx->stack_top - 4096; ptr > (unsigned long)cothread; ptr -= 4096){
|
for(ptr=ctx->stack_top - 4096; ptr > (unsigned long)cothread; ptr -= 4096){
|
||||||
GST_DEBUG (GST_CAT_COTHREADS, "touching location 0x%08lx", ptr);
|
GST_CAT_DEBUG (GST_CAT_COTHREADS, "touching location 0x%08lx", ptr);
|
||||||
*(volatile unsigned int *)ptr = *(volatile unsigned int *)ptr;
|
*(volatile unsigned int *)ptr = *(volatile unsigned int *)ptr;
|
||||||
GST_DEBUG (GST_CAT_COTHREADS, "ok (0x%08x)", *(unsigned int *)ptr);
|
GST_CAT_DEBUG (GST_CAT_COTHREADS, "ok (0x%08x)", *(unsigned int *)ptr);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
@ -268,7 +268,7 @@ cothread_create (cothread_context *ctx)
|
||||||
|
|
||||||
/* The mmap is necessary on Linux/i386, and possibly others, since the
|
/* The mmap is necessary on Linux/i386, and possibly others, since the
|
||||||
* kernel is picky about when we can expand our stack. */
|
* kernel is picky about when we can expand our stack. */
|
||||||
GST_DEBUG (GST_CAT_COTHREADS, "mmaping %p, size 0x%08x", cothread,
|
GST_CAT_DEBUG (GST_CAT_COTHREADS, "mmaping %p, size 0x%08x", cothread,
|
||||||
COTHREAD_STACKSIZE);
|
COTHREAD_STACKSIZE);
|
||||||
/* Remap with a guard page. This decreases our stack size by 8 kB (for
|
/* Remap with a guard page. This decreases our stack size by 8 kB (for
|
||||||
* 4 kB pages) and also wastes almost 4 kB for the cothreads
|
* 4 kB pages) and also wastes almost 4 kB for the cothreads
|
||||||
|
@ -281,7 +281,7 @@ cothread_create (cothread_context *ctx)
|
||||||
COTHREAD_STACKSIZE - page_size * 2,
|
COTHREAD_STACKSIZE - page_size * 2,
|
||||||
PROT_READ | PROT_WRITE | PROT_EXEC,
|
PROT_READ | PROT_WRITE | PROT_EXEC,
|
||||||
MAP_FIXED | MAP_PRIVATE | MAP_ANONYMOUS, -1, 0);
|
MAP_FIXED | MAP_PRIVATE | MAP_ANONYMOUS, -1, 0);
|
||||||
GST_DEBUG (GST_CAT_COTHREADS, "coming out of mmap");
|
GST_CAT_DEBUG (GST_CAT_COTHREADS, "coming out of mmap");
|
||||||
if (mmaped == MAP_FAILED) {
|
if (mmaped == MAP_FAILED) {
|
||||||
perror ("mmap'ing cothread stack space");
|
perror ("mmap'ing cothread stack space");
|
||||||
return NULL;
|
return NULL;
|
||||||
|
@ -292,7 +292,7 @@ cothread_create (cothread_context *ctx)
|
||||||
}
|
}
|
||||||
|
|
||||||
cothread->magic_number = COTHREAD_MAGIC_NUMBER;
|
cothread->magic_number = COTHREAD_MAGIC_NUMBER;
|
||||||
GST_DEBUG (GST_CAT_COTHREADS, "create cothread %d with magic number 0x%x",
|
GST_CAT_DEBUG (GST_CAT_COTHREADS, "create cothread %d with magic number 0x%x",
|
||||||
slot, cothread->magic_number);
|
slot, cothread->magic_number);
|
||||||
cothread->ctx = ctx;
|
cothread->ctx = ctx;
|
||||||
cothread->cothreadnum = slot;
|
cothread->cothreadnum = slot;
|
||||||
|
@ -302,7 +302,7 @@ cothread_create (cothread_context *ctx)
|
||||||
cothread->stack_size = COTHREAD_STACKSIZE - page_size * 2;
|
cothread->stack_size = COTHREAD_STACKSIZE - page_size * 2;
|
||||||
cothread->stack_base = (void *)cothread + 2 * page_size;
|
cothread->stack_base = (void *)cothread + 2 * page_size;
|
||||||
|
|
||||||
GST_INFO (GST_CAT_COTHREADS,
|
GST_CAT_INFO (GST_CAT_COTHREADS,
|
||||||
"created cothread #%d in slot %d: %p at sp:%p",
|
"created cothread #%d in slot %d: %p at sp:%p",
|
||||||
ctx->ncothreads, slot, cothread, cothread->sp);
|
ctx->ncothreads, slot, cothread, cothread->sp);
|
||||||
|
|
||||||
|
@ -323,7 +323,7 @@ cothread_free (cothread_state *cothread)
|
||||||
{
|
{
|
||||||
g_return_if_fail (cothread != NULL);
|
g_return_if_fail (cothread != NULL);
|
||||||
|
|
||||||
GST_INFO (GST_CAT_COTHREADS, "flag cothread %d for destruction",
|
GST_CAT_INFO (GST_CAT_COTHREADS, "flag cothread %d for destruction",
|
||||||
cothread->cothreadnum);
|
cothread->cothreadnum);
|
||||||
|
|
||||||
/* we simply flag the cothread for destruction here */
|
/* we simply flag the cothread for destruction here */
|
||||||
|
@ -346,7 +346,7 @@ cothread_destroy (cothread_state *cothread)
|
||||||
g_assert (ctx->thread == g_thread_self());
|
g_assert (ctx->thread == g_thread_self());
|
||||||
g_assert (ctx == cothread_get_current_context());
|
g_assert (ctx == cothread_get_current_context());
|
||||||
|
|
||||||
GST_INFO (GST_CAT_COTHREADS, "destroy cothread %d %p %d",
|
GST_CAT_INFO (GST_CAT_COTHREADS, "destroy cothread %d %p %d",
|
||||||
cothreadnum, cothread, ctx->current);
|
cothreadnum, cothread, ctx->current);
|
||||||
|
|
||||||
/* cothread 0 needs to be destroyed specially */
|
/* cothread 0 needs to be destroyed specially */
|
||||||
|
@ -357,7 +357,7 @@ cothread_destroy (cothread_state *cothread)
|
||||||
cothread_unlock (cothread);
|
cothread_unlock (cothread);
|
||||||
|
|
||||||
/* doing cleanups of the cothread create */
|
/* doing cleanups of the cothread create */
|
||||||
GST_DEBUG (GST_CAT_COTHREADS, "destroy cothread %d with magic number 0x%x",
|
GST_CAT_DEBUG (GST_CAT_COTHREADS, "destroy cothread %d with magic number 0x%x",
|
||||||
cothreadnum, cothread->magic_number);
|
cothreadnum, cothread->magic_number);
|
||||||
g_assert (cothread->magic_number == COTHREAD_MAGIC_NUMBER);
|
g_assert (cothread->magic_number == COTHREAD_MAGIC_NUMBER);
|
||||||
|
|
||||||
|
@ -411,7 +411,7 @@ cothread_main (cothread_context* ctx)
|
||||||
{
|
{
|
||||||
g_assert (ctx->thread == g_thread_self());
|
g_assert (ctx->thread == g_thread_self());
|
||||||
|
|
||||||
GST_DEBUG (GST_CAT_COTHREADS, "returning %p, the 0th cothread",
|
GST_CAT_DEBUG (GST_CAT_COTHREADS, "returning %p, the 0th cothread",
|
||||||
ctx->cothreads[0]);
|
ctx->cothreads[0]);
|
||||||
return ctx->cothreads[0];
|
return ctx->cothreads[0];
|
||||||
}
|
}
|
||||||
|
@ -451,22 +451,22 @@ cothread_stub (void)
|
||||||
{
|
{
|
||||||
cothread_context *ctx = cothread_get_current_context();
|
cothread_context *ctx = cothread_get_current_context();
|
||||||
cothread_state *cothread = ctx->cothreads[ctx->current];
|
cothread_state *cothread = ctx->cothreads[ctx->current];
|
||||||
|
#ifndef GST_DISABLE_GST_DEBUG
|
||||||
char __csf;
|
char __csf;
|
||||||
void *current_stack_frame = &__csf;
|
void *current_stack_frame = &__csf;
|
||||||
|
#endif
|
||||||
|
|
||||||
GST_DEBUG_ENTER ("");
|
GST_CAT_DEBUG (GST_CAT_COTHREADS, "stack addr %p", &ctx);
|
||||||
|
|
||||||
GST_DEBUG (GST_CAT_COTHREADS, "stack addr %p", &ctx);
|
|
||||||
|
|
||||||
cothread->flags |= COTHREAD_STARTED;
|
cothread->flags |= COTHREAD_STARTED;
|
||||||
|
|
||||||
while (TRUE) {
|
while (TRUE) {
|
||||||
cothread->func (cothread->argc, cothread->argv);
|
cothread->func (cothread->argc, cothread->argv);
|
||||||
|
|
||||||
GST_DEBUG (GST_CAT_COTHREADS, "cothread[%d] thread->func exited", ctx->current);
|
GST_CAT_DEBUG (GST_CAT_COTHREADS, "cothread[%d] thread->func exited", ctx->current);
|
||||||
|
|
||||||
GST_DEBUG (GST_CAT_COTHREADS, "sp=%p", current_stack_frame);
|
GST_CAT_DEBUG (GST_CAT_COTHREADS, "sp=%p", current_stack_frame);
|
||||||
GST_DEBUG (GST_CAT_COTHREADS, "ctx=%p current=%p", ctx,cothread_get_current_context());
|
GST_CAT_DEBUG (GST_CAT_COTHREADS, "ctx=%p current=%p", ctx,cothread_get_current_context());
|
||||||
g_assert (ctx == cothread_get_current_context());
|
g_assert (ctx == cothread_get_current_context());
|
||||||
|
|
||||||
g_assert (ctx->current != 0);
|
g_assert (ctx->current != 0);
|
||||||
|
@ -474,7 +474,6 @@ cothread_stub (void)
|
||||||
/* we do this to avoid ever returning, we just switch to 0th thread */
|
/* we do this to avoid ever returning, we just switch to 0th thread */
|
||||||
cothread_switch (cothread_main (ctx));
|
cothread_switch (cothread_main (ctx));
|
||||||
}
|
}
|
||||||
GST_DEBUG_LEAVE ("");
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -594,26 +593,23 @@ cothread_switch (cothread_state *cothread)
|
||||||
|
|
||||||
|
|
||||||
/* find the number of the thread to switch to */
|
/* find the number of the thread to switch to */
|
||||||
GST_INFO (GST_CAT_COTHREAD_SWITCH,
|
GST_CAT_INFO (GST_CAT_COTHREAD_SWITCH,
|
||||||
"switching from cothread #%d to cothread #%d",
|
"switching from cothread #%d to cothread #%d",
|
||||||
ctx->current, cothread->cothreadnum);
|
ctx->current, cothread->cothreadnum);
|
||||||
ctx->current = cothread->cothreadnum;
|
ctx->current = cothread->cothreadnum;
|
||||||
|
|
||||||
g_static_private_set (&_gst_debug_cothread_index,
|
|
||||||
GINT_TO_POINTER(ctx->current), NULL);
|
|
||||||
|
|
||||||
/* save the current stack pointer, frame pointer, and pc */
|
/* save the current stack pointer, frame pointer, and pc */
|
||||||
#ifdef GST_ARCH_PRESETJMP
|
#ifdef GST_ARCH_PRESETJMP
|
||||||
GST_ARCH_PRESETJMP ();
|
GST_ARCH_PRESETJMP ();
|
||||||
#endif
|
#endif
|
||||||
enter = setjmp (current->jmp);
|
enter = setjmp (current->jmp);
|
||||||
if (enter != 0) {
|
if (enter != 0) {
|
||||||
GST_DEBUG (GST_CAT_COTHREADS,
|
GST_CAT_DEBUG (GST_CAT_COTHREADS,
|
||||||
"enter cothread #%d %d sp=%p jmpbuf=%p",
|
"enter cothread #%d %d sp=%p jmpbuf=%p",
|
||||||
current->cothreadnum, enter, current->sp, current->jmp);
|
current->cothreadnum, enter, current->sp, current->jmp);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
GST_DEBUG (GST_CAT_COTHREADS, "exit cothread #%d %d sp=%p jmpbuf=%p",
|
GST_CAT_DEBUG (GST_CAT_COTHREADS, "exit cothread #%d %d sp=%p jmpbuf=%p",
|
||||||
current->cothreadnum, enter, current->sp, current->jmp);
|
current->cothreadnum, enter, current->sp, current->jmp);
|
||||||
enter = 1;
|
enter = 1;
|
||||||
|
|
||||||
|
@ -621,10 +617,10 @@ cothread_switch (cothread_state *cothread)
|
||||||
cothread_destroy (current);
|
cothread_destroy (current);
|
||||||
}
|
}
|
||||||
|
|
||||||
GST_DEBUG (GST_CAT_COTHREADS, "set stack to %p", cothread->sp);
|
GST_CAT_DEBUG (GST_CAT_COTHREADS, "set stack to %p", cothread->sp);
|
||||||
/* restore stack pointer and other stuff of new cothread */
|
/* restore stack pointer and other stuff of new cothread */
|
||||||
if (cothread->flags & COTHREAD_STARTED) {
|
if (cothread->flags & COTHREAD_STARTED) {
|
||||||
GST_DEBUG (GST_CAT_COTHREADS, "via longjmp() jmpbuf %p", cothread->jmp);
|
GST_CAT_DEBUG (GST_CAT_COTHREADS, "via longjmp() jmpbuf %p", cothread->jmp);
|
||||||
/* switch to it */
|
/* switch to it */
|
||||||
longjmp (cothread->jmp, 1);
|
longjmp (cothread->jmp, 1);
|
||||||
}
|
}
|
||||||
|
@ -632,7 +628,7 @@ cothread_switch (cothread_state *cothread)
|
||||||
#ifdef HAVE_MAKECONTEXT
|
#ifdef HAVE_MAKECONTEXT
|
||||||
ucontext_t ucp;
|
ucontext_t ucp;
|
||||||
|
|
||||||
GST_DEBUG (GST_CAT_COTHREADS, "making context");
|
GST_CAT_DEBUG (GST_CAT_COTHREADS, "making context");
|
||||||
|
|
||||||
g_assert (cothread != cothread_main(ctx));
|
g_assert (cothread != cothread_main(ctx));
|
||||||
|
|
||||||
|
@ -648,7 +644,7 @@ cothread_switch (cothread_state *cothread)
|
||||||
GST_ARCH_CALL (cothread_stub);
|
GST_ARCH_CALL (cothread_stub);
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
GST_DEBUG (GST_CAT_COTHREADS, "exit thread ");
|
GST_CAT_DEBUG (GST_CAT_COTHREADS, "exit thread ");
|
||||||
ctx->current = 0;
|
ctx->current = 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -20,8 +20,14 @@
|
||||||
* Boston, MA 02111-1307, USA.
|
* Boston, MA 02111-1307, USA.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
#ifdef HAVE_CONFIG_H
|
||||||
|
# include "config.h"
|
||||||
|
#endif
|
||||||
|
|
||||||
#include "gstaggregator.h"
|
#include "gstaggregator.h"
|
||||||
|
|
||||||
|
GST_DEBUG_CATEGORY (gst_aggregator_debug);
|
||||||
|
#define GST_CAT_DEFAULT gst_aggregator_debug
|
||||||
|
|
||||||
GstElementDetails gst_aggregator_details = {
|
GstElementDetails gst_aggregator_details = {
|
||||||
"Aggregator pipe fitting",
|
"Aggregator pipe fitting",
|
||||||
|
@ -354,4 +360,3 @@ gst_aggregator_factory_init (GstElementFactory *factory)
|
||||||
|
|
||||||
return TRUE;
|
return TRUE;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -29,6 +29,7 @@
|
||||||
G_BEGIN_DECLS
|
G_BEGIN_DECLS
|
||||||
|
|
||||||
extern GstElementDetails gst_aggregator_details;
|
extern GstElementDetails gst_aggregator_details;
|
||||||
|
GST_DEBUG_CATEGORY_EXTERN(gst_aggregator_debug);
|
||||||
|
|
||||||
typedef enum {
|
typedef enum {
|
||||||
AGGREGATOR_LOOP = 1,
|
AGGREGATOR_LOOP = 1,
|
||||||
|
|
|
@ -21,8 +21,13 @@
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
#ifdef HAVE_CONFIG_H
|
||||||
|
# include "config.h"
|
||||||
|
#endif
|
||||||
|
|
||||||
#include <gst/gst.h>
|
#include <gst/gst.h>
|
||||||
|
|
||||||
|
#include "gstfilesrc.h"
|
||||||
#include "gstfilesink.h"
|
#include "gstfilesink.h"
|
||||||
#include "gstidentity.h"
|
#include "gstidentity.h"
|
||||||
#include "gstfakesink.h"
|
#include "gstfakesink.h"
|
||||||
|
@ -75,6 +80,21 @@ plugin_init (GModule *module, GstPlugin *plugin)
|
||||||
|
|
||||||
gst_plugin_set_longname (plugin, "Standard GST Elements");
|
gst_plugin_set_longname (plugin, "Standard GST Elements");
|
||||||
|
|
||||||
|
GST_DEBUG_CATEGORY_INIT (gst_fakesrc_debug, "fakesrc", 0, "fakesrc element");
|
||||||
|
GST_DEBUG_CATEGORY_INIT (gst_fakesink_debug, "fakesink", 0, "fakesink element");
|
||||||
|
GST_DEBUG_CATEGORY_INIT (gst_filesrc_debug, "filesrc", 0, "filesrc element");
|
||||||
|
GST_DEBUG_CATEGORY_INIT (gst_filesink_debug, "fakesink", 0, "filesink element");
|
||||||
|
GST_DEBUG_CATEGORY_INIT (gst_identity_debug, "identity", 0, "identity element");
|
||||||
|
GST_DEBUG_CATEGORY_INIT (gst_fdsrc_debug, "fdsrc", 0, "fdsrc element");
|
||||||
|
GST_DEBUG_CATEGORY_INIT (gst_fdsink_debug, "fdsink", 0, "fdsink element");
|
||||||
|
GST_DEBUG_CATEGORY_INIT (gst_multidisksrc_debug, "multidisksrc", 0, "multidisksrc element");
|
||||||
|
GST_DEBUG_CATEGORY_INIT (gst_pipefilter_debug, "pipefilter", 0, "pipefilter element");
|
||||||
|
GST_DEBUG_CATEGORY_INIT (gst_tee_debug, "tee", 0, "tee element");
|
||||||
|
GST_DEBUG_CATEGORY_INIT (gst_aggregator_debug, "aggregator", 0, "aggregator element");
|
||||||
|
GST_DEBUG_CATEGORY_INIT (gst_shaper_debug, "shaper", 0, "shaper element");
|
||||||
|
GST_DEBUG_CATEGORY_INIT (gst_statistics_debug, "statistics", 0, "statistics element");
|
||||||
|
GST_DEBUG_CATEGORY_INIT (gst_md5sink_debug, "md5sink", 0, "md5sink element");
|
||||||
|
|
||||||
while (_elements[i].name) {
|
while (_elements[i].name) {
|
||||||
factory = gst_element_factory_new (_elements[i].name,
|
factory = gst_element_factory_new (_elements[i].name,
|
||||||
(_elements[i].type) (),
|
(_elements[i].type) (),
|
||||||
|
@ -107,4 +127,3 @@ GstPluginDesc plugin_desc = {
|
||||||
"gstelements",
|
"gstelements",
|
||||||
plugin_init
|
plugin_init
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
|
@ -21,8 +21,14 @@
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
|
||||||
#include <gstfakesink.h>
|
#ifdef HAVE_CONFIG_H
|
||||||
|
# include "config.h"
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#include "gstfakesink.h"
|
||||||
|
|
||||||
|
GST_DEBUG_CATEGORY (gst_fakesink_debug);
|
||||||
|
#define GST_CAT_DEFAULT gst_fakesink_debug
|
||||||
|
|
||||||
GstElementDetails gst_fakesink_details = {
|
GstElementDetails gst_fakesink_details = {
|
||||||
"Fake Sink",
|
"Fake Sink",
|
||||||
|
|
|
@ -24,14 +24,12 @@
|
||||||
#ifndef __GST_FAKESINK_H__
|
#ifndef __GST_FAKESINK_H__
|
||||||
#define __GST_FAKESINK_H__
|
#define __GST_FAKESINK_H__
|
||||||
|
|
||||||
|
|
||||||
#include <config.h>
|
|
||||||
#include <gst/gst.h>
|
#include <gst/gst.h>
|
||||||
|
|
||||||
G_BEGIN_DECLS
|
G_BEGIN_DECLS
|
||||||
|
|
||||||
GstElementDetails gst_fakesink_details;
|
extern GstElementDetails gst_fakesink_details;
|
||||||
|
GST_DEBUG_CATEGORY_EXTERN(gst_fakesink_debug);
|
||||||
|
|
||||||
#define GST_TYPE_FAKESINK \
|
#define GST_TYPE_FAKESINK \
|
||||||
(gst_fakesink_get_type())
|
(gst_fakesink_get_type())
|
||||||
|
|
|
@ -24,12 +24,19 @@
|
||||||
#include <stdlib.h>
|
#include <stdlib.h>
|
||||||
#include <string.h>
|
#include <string.h>
|
||||||
|
|
||||||
#include <gstfakesrc.h>
|
#ifdef HAVE_CONFIG_H
|
||||||
|
# include "config.h"
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#include "gstfakesrc.h"
|
||||||
|
|
||||||
#define DEFAULT_SIZEMIN 0
|
#define DEFAULT_SIZEMIN 0
|
||||||
#define DEFAULT_SIZEMAX 4096
|
#define DEFAULT_SIZEMAX 4096
|
||||||
#define DEFAULT_PARENTSIZE 4096*10
|
#define DEFAULT_PARENTSIZE 4096*10
|
||||||
|
|
||||||
|
GST_DEBUG_CATEGORY (gst_fakesrc_debug);
|
||||||
|
#define GST_CAT_DEFAULT gst_fakesrc_debug
|
||||||
|
|
||||||
GstElementDetails gst_fakesrc_details = {
|
GstElementDetails gst_fakesrc_details = {
|
||||||
"Fake Source",
|
"Fake Source",
|
||||||
"Source",
|
"Source",
|
||||||
|
@ -502,7 +509,7 @@ gst_fakesrc_set_property (GObject *object, guint prop_id, const GValue *value, G
|
||||||
break;
|
break;
|
||||||
case ARG_EOS:
|
case ARG_EOS:
|
||||||
src->eos = g_value_get_boolean (value);
|
src->eos = g_value_get_boolean (value);
|
||||||
GST_INFO (0, "will EOS on next buffer");
|
GST_INFO ( "will EOS on next buffer");
|
||||||
break;
|
break;
|
||||||
case ARG_SILENT:
|
case ARG_SILENT:
|
||||||
src->silent = g_value_get_boolean (value);
|
src->silent = g_value_get_boolean (value);
|
||||||
|
@ -753,7 +760,7 @@ gst_fakesrc_get(GstPad *pad)
|
||||||
}
|
}
|
||||||
|
|
||||||
if (src->eos) {
|
if (src->eos) {
|
||||||
GST_INFO (0, "fakesrc is setting eos on pad");
|
GST_INFO ( "fakesrc is setting eos on pad");
|
||||||
return GST_BUFFER(gst_event_new (GST_EVENT_EOS));
|
return GST_BUFFER(gst_event_new (GST_EVENT_EOS));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -770,10 +777,10 @@ gst_fakesrc_get(GstPad *pad)
|
||||||
g_object_notify (G_OBJECT (src), "last_message");
|
g_object_notify (G_OBJECT (src), "last_message");
|
||||||
}
|
}
|
||||||
|
|
||||||
GST_DEBUG_ELEMENT (GST_CAT_DATAFLOW, src, "pre handoff emit");
|
GST_LOG_OBJECT (src, "pre handoff emit");
|
||||||
g_signal_emit (G_OBJECT (src), gst_fakesrc_signals[SIGNAL_HANDOFF], 0,
|
g_signal_emit (G_OBJECT (src), gst_fakesrc_signals[SIGNAL_HANDOFF], 0,
|
||||||
buf, pad);
|
buf, pad);
|
||||||
GST_DEBUG_ELEMENT (GST_CAT_DATAFLOW, src, "post handoff emit");
|
GST_LOG_OBJECT (src, "post handoff emit");
|
||||||
|
|
||||||
return buf;
|
return buf;
|
||||||
}
|
}
|
||||||
|
@ -866,4 +873,3 @@ gst_fakesrc_factory_init (GstElementFactory *factory)
|
||||||
|
|
||||||
return TRUE;
|
return TRUE;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -24,13 +24,12 @@
|
||||||
#ifndef __GST_FAKESRC_H__
|
#ifndef __GST_FAKESRC_H__
|
||||||
#define __GST_FAKESRC_H__
|
#define __GST_FAKESRC_H__
|
||||||
|
|
||||||
|
|
||||||
#include <config.h>
|
|
||||||
#include <gst/gst.h>
|
#include <gst/gst.h>
|
||||||
|
|
||||||
G_BEGIN_DECLS
|
G_BEGIN_DECLS
|
||||||
|
|
||||||
GstElementDetails gst_fakesrc_details;
|
extern GstElementDetails gst_fakesrc_details;
|
||||||
|
GST_DEBUG_CATEGORY_EXTERN(gst_fakesrc_debug);
|
||||||
|
|
||||||
typedef enum {
|
typedef enum {
|
||||||
FAKESRC_FIRST_LAST_LOOP = 1,
|
FAKESRC_FIRST_LAST_LOOP = 1,
|
||||||
|
|
|
@ -20,9 +20,15 @@
|
||||||
* Boston, MA 02111-1307, USA.
|
* Boston, MA 02111-1307, USA.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#include <gstfdsink.h>
|
#ifdef HAVE_CONFIG_H
|
||||||
|
# include "config.h"
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#include "gstfdsink.h"
|
||||||
#include <unistd.h>
|
#include <unistd.h>
|
||||||
|
|
||||||
|
GST_DEBUG_CATEGORY (gst_fdsink_debug);
|
||||||
|
#define GST_CAT_DEFAULT gst_fdsink_debug
|
||||||
|
|
||||||
GstElementDetails gst_fdsink_details = {
|
GstElementDetails gst_fdsink_details = {
|
||||||
"Filedescriptor Sink",
|
"Filedescriptor Sink",
|
||||||
|
@ -122,7 +128,7 @@ gst_fdsink_chain (GstPad *pad, GstBuffer *buf)
|
||||||
g_return_if_fail (fdsink->fd >= 0);
|
g_return_if_fail (fdsink->fd >= 0);
|
||||||
|
|
||||||
if (GST_BUFFER_DATA (buf)) {
|
if (GST_BUFFER_DATA (buf)) {
|
||||||
GST_DEBUG (0,"writing %d bytes to file descriptor %d",GST_BUFFER_SIZE (buf), fdsink->fd);
|
GST_DEBUG ("writing %d bytes to file descriptor %d",GST_BUFFER_SIZE (buf), fdsink->fd);
|
||||||
write (fdsink->fd, GST_BUFFER_DATA (buf), GST_BUFFER_SIZE (buf));
|
write (fdsink->fd, GST_BUFFER_DATA (buf), GST_BUFFER_SIZE (buf));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -24,14 +24,12 @@
|
||||||
#ifndef __GST_FDSINK_H__
|
#ifndef __GST_FDSINK_H__
|
||||||
#define __GST_FDSINK_H__
|
#define __GST_FDSINK_H__
|
||||||
|
|
||||||
|
|
||||||
#include <config.h>
|
|
||||||
#include <gst/gst.h>
|
#include <gst/gst.h>
|
||||||
|
|
||||||
G_BEGIN_DECLS
|
G_BEGIN_DECLS
|
||||||
|
|
||||||
GstElementDetails gst_fdsink_details;
|
extern GstElementDetails gst_fdsink_details;
|
||||||
|
GST_DEBUG_CATEGORY_EXTERN(gst_fdsink_debug);
|
||||||
|
|
||||||
#define GST_TYPE_FDSINK \
|
#define GST_TYPE_FDSINK \
|
||||||
(gst_fdsink_get_type())
|
(gst_fdsink_get_type())
|
||||||
|
|
|
@ -27,10 +27,17 @@
|
||||||
#include <unistd.h>
|
#include <unistd.h>
|
||||||
#include <stdlib.h>
|
#include <stdlib.h>
|
||||||
|
|
||||||
#include <gstfdsrc.h>
|
#ifdef HAVE_CONFIG_H
|
||||||
|
# include "config.h"
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#include "gstfdsrc.h"
|
||||||
|
|
||||||
#define DEFAULT_BLOCKSIZE 4096
|
#define DEFAULT_BLOCKSIZE 4096
|
||||||
|
|
||||||
|
GST_DEBUG_CATEGORY (gst_fdsrc_debug);
|
||||||
|
#define GST_CAT_DEFAULT gst_fdsrc_debug
|
||||||
|
|
||||||
GstElementDetails gst_fdsrc_details =
|
GstElementDetails gst_fdsrc_details =
|
||||||
{
|
{
|
||||||
"Disk Source",
|
"Disk Source",
|
||||||
|
|
|
@ -24,14 +24,12 @@
|
||||||
#ifndef __GST_FDSRC_H__
|
#ifndef __GST_FDSRC_H__
|
||||||
#define __GST_FDSRC_H__
|
#define __GST_FDSRC_H__
|
||||||
|
|
||||||
|
|
||||||
#include <config.h>
|
|
||||||
#include <gst/gst.h>
|
#include <gst/gst.h>
|
||||||
|
|
||||||
G_BEGIN_DECLS
|
G_BEGIN_DECLS
|
||||||
|
|
||||||
GstElementDetails gst_fdsrc_details;
|
extern GstElementDetails gst_fdsrc_details;
|
||||||
|
GST_DEBUG_CATEGORY_EXTERN(gst_fdsrc_debug);
|
||||||
|
|
||||||
#define GST_TYPE_FDSRC \
|
#define GST_TYPE_FDSRC \
|
||||||
(gst_fdsrc_get_type())
|
(gst_fdsrc_get_type())
|
||||||
|
|
|
@ -21,11 +21,18 @@
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
#ifdef HAVE_CONFIG_H
|
||||||
|
# include "config.h"
|
||||||
|
#endif
|
||||||
|
|
||||||
#include <gst/gst.h>
|
#include <gst/gst.h>
|
||||||
#include <errno.h>
|
#include <errno.h>
|
||||||
#include "gstfilesink.h"
|
#include "gstfilesink.h"
|
||||||
#include <string.h>
|
#include <string.h>
|
||||||
|
|
||||||
|
GST_DEBUG_CATEGORY (gst_filesink_debug);
|
||||||
|
#define GST_CAT_DEFAULT gst_filesink_debug
|
||||||
|
|
||||||
GstElementDetails gst_filesink_details = {
|
GstElementDetails gst_filesink_details = {
|
||||||
"File Sink",
|
"File Sink",
|
||||||
"Sink/File",
|
"Sink/File",
|
||||||
|
|
|
@ -24,14 +24,12 @@
|
||||||
#ifndef __GST_FILESINK_H__
|
#ifndef __GST_FILESINK_H__
|
||||||
#define __GST_FILESINK_H__
|
#define __GST_FILESINK_H__
|
||||||
|
|
||||||
|
|
||||||
#include <config.h>
|
|
||||||
#include <gst/gst.h>
|
#include <gst/gst.h>
|
||||||
|
|
||||||
G_BEGIN_DECLS
|
G_BEGIN_DECLS
|
||||||
|
|
||||||
GstElementDetails gst_filesink_details;
|
extern GstElementDetails gst_filesink_details;
|
||||||
|
GST_DEBUG_CATEGORY_EXTERN(gst_filesink_debug);
|
||||||
|
|
||||||
#define GST_TYPE_FILESINK \
|
#define GST_TYPE_FILESINK \
|
||||||
(gst_filesink_get_type())
|
(gst_filesink_get_type())
|
||||||
|
|
|
@ -20,8 +20,11 @@
|
||||||
* Boston, MA 02111-1307, USA.
|
* Boston, MA 02111-1307, USA.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#include <gst/gst.h>
|
#ifdef HAVE_CONFIG_H
|
||||||
|
# include "config.h"
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#include <gst/gst.h>
|
||||||
#include "gstfilesrc.h"
|
#include "gstfilesrc.h"
|
||||||
|
|
||||||
#include <stdio.h>
|
#include <stdio.h>
|
||||||
|
@ -69,6 +72,9 @@
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
GST_DEBUG_CATEGORY (gst_filesrc_debug);
|
||||||
|
#define GST_CAT_DEFAULT gst_filesrc_debug
|
||||||
|
|
||||||
GstElementDetails gst_filesrc_details = {
|
GstElementDetails gst_filesrc_details = {
|
||||||
"File Source",
|
"File Source",
|
||||||
"Source/File",
|
"Source/File",
|
||||||
|
@ -299,7 +305,7 @@ gst_filesrc_set_property (GObject *object, guint prop_id, const GValue *value, G
|
||||||
src->mapsize = g_value_get_ulong (value);
|
src->mapsize = g_value_get_ulong (value);
|
||||||
g_object_notify (G_OBJECT (src), "mmapsize");
|
g_object_notify (G_OBJECT (src), "mmapsize");
|
||||||
} else {
|
} else {
|
||||||
GST_INFO (0, "invalid mapsize, must a multiple of pagesize, which is %d",
|
GST_INFO ( "invalid mapsize, must a multiple of pagesize, which is %d",
|
||||||
src->pagesize);
|
src->pagesize);
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
|
@ -369,7 +375,7 @@ gst_filesrc_free_parent_mmap (GstBuffer *buf)
|
||||||
munmap (GST_BUFFER_DATA (buf), GST_BUFFER_MAXSIZE (buf));
|
munmap (GST_BUFFER_DATA (buf), GST_BUFFER_MAXSIZE (buf));
|
||||||
/* cast to unsigned long, since there's no gportable way to print
|
/* cast to unsigned long, since there's no gportable way to print
|
||||||
* guint64 as hex */
|
* guint64 as hex */
|
||||||
GST_DEBUG (0, "unmapped region %08lx+%08lx at %p",
|
GST_DEBUG ( "unmapped region %08lx+%08lx at %p",
|
||||||
(unsigned long) GST_BUFFER_OFFSET (buf),
|
(unsigned long) GST_BUFFER_OFFSET (buf),
|
||||||
(unsigned long) GST_BUFFER_MAXSIZE (buf),
|
(unsigned long) GST_BUFFER_MAXSIZE (buf),
|
||||||
GST_BUFFER_DATA (buf));
|
GST_BUFFER_DATA (buf));
|
||||||
|
@ -400,7 +406,7 @@ gst_filesrc_map_region (GstFileSrc *src, off_t offset, size_t size)
|
||||||
size, src->fd, offset, strerror (errno));
|
size, src->fd, offset, strerror (errno));
|
||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
GST_DEBUG (0, "mapped region %08lx+%08lx from file into memory at %p",
|
GST_DEBUG ( "mapped region %08lx+%08lx from file into memory at %p",
|
||||||
(unsigned long)offset, (unsigned long)size, mmapregion);
|
(unsigned long)offset, (unsigned long)size, mmapregion);
|
||||||
|
|
||||||
/* time to allocate a new mapbuf */
|
/* time to allocate a new mapbuf */
|
||||||
|
@ -504,7 +510,7 @@ gst_filesrc_get (GstPad *pad)
|
||||||
GstEvent *event;
|
GstEvent *event;
|
||||||
|
|
||||||
src->seek_happened = FALSE;
|
src->seek_happened = FALSE;
|
||||||
GST_DEBUG (GST_CAT_EVENT, "filesrc sending discont");
|
GST_DEBUG ("filesrc sending discont");
|
||||||
event = gst_event_new_discontinuous (FALSE, GST_FORMAT_BYTES, src->curoffset, NULL);
|
event = gst_event_new_discontinuous (FALSE, GST_FORMAT_BYTES, src->curoffset, NULL);
|
||||||
src->need_flush = FALSE;
|
src->need_flush = FALSE;
|
||||||
return GST_BUFFER (event);
|
return GST_BUFFER (event);
|
||||||
|
@ -512,14 +518,14 @@ gst_filesrc_get (GstPad *pad)
|
||||||
/* check for flush */
|
/* check for flush */
|
||||||
if (src->need_flush) {
|
if (src->need_flush) {
|
||||||
src->need_flush = FALSE;
|
src->need_flush = FALSE;
|
||||||
GST_DEBUG (GST_CAT_EVENT, "filesrc sending flush");
|
GST_DEBUG ("filesrc sending flush");
|
||||||
return GST_BUFFER (gst_event_new_flush ());
|
return GST_BUFFER (gst_event_new_flush ());
|
||||||
}
|
}
|
||||||
|
|
||||||
/* check for EOF */
|
/* check for EOF */
|
||||||
if (src->curoffset == src->filelen) {
|
if (src->curoffset == src->filelen) {
|
||||||
GST_DEBUG (0, "filesrc eos %" G_GINT64_FORMAT
|
GST_DEBUG ("filesrc eos %" G_GINT64_FORMAT" %" G_GINT64_FORMAT,
|
||||||
" %" G_GINT64_FORMAT, src->curoffset, src->filelen);
|
src->curoffset, src->filelen);
|
||||||
gst_element_set_eos (GST_ELEMENT (src));
|
gst_element_set_eos (GST_ELEMENT (src));
|
||||||
return GST_BUFFER (gst_event_new (GST_EVENT_EOS));
|
return GST_BUFFER (gst_event_new (GST_EVENT_EOS));
|
||||||
}
|
}
|
||||||
|
@ -537,7 +543,7 @@ gst_filesrc_get (GstPad *pad)
|
||||||
readend = src->curoffset + readsize;
|
readend = src->curoffset + readsize;
|
||||||
}
|
}
|
||||||
|
|
||||||
GST_DEBUG (0, "attempting to read %08lx, %08lx, %08lx, %08lx",
|
GST_LOG ("attempting to read %08lx, %08lx, %08lx, %08lx",
|
||||||
(unsigned long)readsize, (unsigned long)readend,
|
(unsigned long)readsize, (unsigned long)readend,
|
||||||
(unsigned long)mapstart, (unsigned long)mapend);
|
(unsigned long)mapstart, (unsigned long)mapend);
|
||||||
|
|
||||||
|
@ -649,7 +655,7 @@ gst_filesrc_open_file (GstFileSrc *src)
|
||||||
{
|
{
|
||||||
g_return_val_if_fail (!GST_FLAG_IS_SET (src ,GST_FILESRC_OPEN), FALSE);
|
g_return_val_if_fail (!GST_FLAG_IS_SET (src ,GST_FILESRC_OPEN), FALSE);
|
||||||
|
|
||||||
GST_DEBUG(0, "opening file %s",src->filename);
|
GST_DEBUG ( "opening file %s",src->filename);
|
||||||
|
|
||||||
/* open the file */
|
/* open the file */
|
||||||
src->fd = open (src->filename, O_RDONLY);
|
src->fd = open (src->filename, O_RDONLY);
|
||||||
|
@ -779,7 +785,7 @@ gst_filesrc_srcpad_event (GstPad *pad, GstEvent *event)
|
||||||
{
|
{
|
||||||
GstFileSrc *src = GST_FILESRC (GST_PAD_PARENT (pad));
|
GstFileSrc *src = GST_FILESRC (GST_PAD_PARENT (pad));
|
||||||
|
|
||||||
GST_DEBUG(0, "event %d", GST_EVENT_TYPE (event));
|
GST_DEBUG ( "event %d", GST_EVENT_TYPE (event));
|
||||||
|
|
||||||
switch (GST_EVENT_TYPE (event)) {
|
switch (GST_EVENT_TYPE (event)) {
|
||||||
case GST_EVENT_SEEK:
|
case GST_EVENT_SEEK:
|
||||||
|
@ -797,19 +803,19 @@ gst_filesrc_srcpad_event (GstPad *pad, GstEvent *event)
|
||||||
if (offset > src->filelen)
|
if (offset > src->filelen)
|
||||||
goto error;
|
goto error;
|
||||||
src->curoffset = offset;
|
src->curoffset = offset;
|
||||||
GST_DEBUG(0, "seek set pending to %" G_GINT64_FORMAT, src->curoffset);
|
GST_DEBUG ( "seek set pending to %" G_GINT64_FORMAT, src->curoffset);
|
||||||
break;
|
break;
|
||||||
case GST_SEEK_METHOD_CUR:
|
case GST_SEEK_METHOD_CUR:
|
||||||
if (offset + src->curoffset > src->filelen)
|
if (offset + src->curoffset > src->filelen)
|
||||||
goto error;
|
goto error;
|
||||||
src->curoffset += offset;
|
src->curoffset += offset;
|
||||||
GST_DEBUG(0, "seek cur pending to %" G_GINT64_FORMAT, src->curoffset);
|
GST_DEBUG ( "seek cur pending to %" G_GINT64_FORMAT, src->curoffset);
|
||||||
break;
|
break;
|
||||||
case GST_SEEK_METHOD_END:
|
case GST_SEEK_METHOD_END:
|
||||||
if (ABS (offset) > src->filelen)
|
if (ABS (offset) > src->filelen)
|
||||||
goto error;
|
goto error;
|
||||||
src->curoffset = src->filelen - ABS (offset);
|
src->curoffset = src->filelen - ABS (offset);
|
||||||
GST_DEBUG(0, "seek end pending to %" G_GINT64_FORMAT, src->curoffset);
|
GST_DEBUG ( "seek end pending to %" G_GINT64_FORMAT, src->curoffset);
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
goto error;
|
goto error;
|
||||||
|
|
|
@ -30,6 +30,9 @@
|
||||||
|
|
||||||
G_BEGIN_DECLS
|
G_BEGIN_DECLS
|
||||||
|
|
||||||
|
extern GstElementDetails gst_filesrc_details;
|
||||||
|
GST_DEBUG_CATEGORY_EXTERN(gst_filesrc_debug);
|
||||||
|
|
||||||
#define GST_TYPE_FILESRC \
|
#define GST_TYPE_FILESRC \
|
||||||
(gst_filesrc_get_type())
|
(gst_filesrc_get_type())
|
||||||
#define GST_FILESRC(obj) \
|
#define GST_FILESRC(obj) \
|
||||||
|
|
|
@ -22,8 +22,15 @@
|
||||||
|
|
||||||
|
|
||||||
#include <stdlib.h>
|
#include <stdlib.h>
|
||||||
#include <gstidentity.h>
|
|
||||||
|
|
||||||
|
#ifdef HAVE_CONFIG_H
|
||||||
|
# include "config.h"
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#include "gstidentity.h"
|
||||||
|
|
||||||
|
GST_DEBUG_CATEGORY (gst_identity_debug);
|
||||||
|
#define GST_CAT_DEFAULT gst_identity_debug
|
||||||
|
|
||||||
GstElementDetails gst_identity_details = {
|
GstElementDetails gst_identity_details = {
|
||||||
"Identity",
|
"Identity",
|
||||||
|
@ -282,7 +289,7 @@ gst_identity_chain (GstPad *pad, GstBuffer *buf)
|
||||||
gst_pad_push (identity->srcpad, buf);
|
gst_pad_push (identity->srcpad, buf);
|
||||||
|
|
||||||
if (identity->sleep_time)
|
if (identity->sleep_time)
|
||||||
usleep (identity->sleep_time);
|
g_usleep (identity->sleep_time);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -25,13 +25,12 @@
|
||||||
#define __GST_IDENTITY_H__
|
#define __GST_IDENTITY_H__
|
||||||
|
|
||||||
|
|
||||||
#include <config.h>
|
|
||||||
#include <gst/gst.h>
|
#include <gst/gst.h>
|
||||||
|
|
||||||
G_BEGIN_DECLS
|
G_BEGIN_DECLS
|
||||||
|
|
||||||
GstElementDetails gst_identity_details;
|
extern GstElementDetails gst_identity_details;
|
||||||
|
GST_DEBUG_CATEGORY_EXTERN(gst_identity_debug);
|
||||||
|
|
||||||
#define GST_TYPE_IDENTITY \
|
#define GST_TYPE_IDENTITY \
|
||||||
(gst_identity_get_type())
|
(gst_identity_get_type())
|
||||||
|
|
|
@ -25,11 +25,16 @@
|
||||||
|
|
||||||
#include <string.h>
|
#include <string.h>
|
||||||
|
|
||||||
#include <config.h>
|
#ifdef HAVE_CONFIG_H
|
||||||
#include <gst/gst.h>
|
# include "config.h"
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#include <gst/gst.h>
|
||||||
#include "gstmd5sink.h"
|
#include "gstmd5sink.h"
|
||||||
|
|
||||||
|
GST_DEBUG_CATEGORY (gst_md5sink_debug);
|
||||||
|
#define GST_CAT_DEFAULT gst_md5sink_debug
|
||||||
|
|
||||||
/* MD5Sink signals and args */
|
/* MD5Sink signals and args */
|
||||||
enum {
|
enum {
|
||||||
/* FILL ME */
|
/* FILL ME */
|
||||||
|
@ -519,4 +524,3 @@ gst_md5sink_factory_init (GstElementFactory *factory)
|
||||||
|
|
||||||
return TRUE;
|
return TRUE;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -25,13 +25,12 @@
|
||||||
#define __GST_MD5SINK_H__
|
#define __GST_MD5SINK_H__
|
||||||
|
|
||||||
|
|
||||||
#include <config.h>
|
|
||||||
#include <gst/gst.h>
|
#include <gst/gst.h>
|
||||||
|
|
||||||
G_BEGIN_DECLS
|
G_BEGIN_DECLS
|
||||||
|
|
||||||
GstElementDetails gst_md5sink_details;
|
extern GstElementDetails gst_md5sink_details;
|
||||||
|
GST_DEBUG_CATEGORY_EXTERN(gst_md5sink_debug);
|
||||||
|
|
||||||
#define GST_TYPE_MD5SINK \
|
#define GST_TYPE_MD5SINK \
|
||||||
(gst_md5sink_get_type())
|
(gst_md5sink_get_type())
|
||||||
|
|
|
@ -27,10 +27,15 @@
|
||||||
#include <unistd.h>
|
#include <unistd.h>
|
||||||
#include <sys/mman.h>
|
#include <sys/mman.h>
|
||||||
|
|
||||||
/*#define GST_DEBUG_ENABLED*/
|
#ifdef HAVE_CONFIG_H
|
||||||
|
# include "config.h"
|
||||||
|
#endif
|
||||||
|
|
||||||
#include "gstmultidisksrc.h"
|
#include "gstmultidisksrc.h"
|
||||||
|
|
||||||
|
GST_DEBUG_CATEGORY (gst_multidisksrc_debug);
|
||||||
|
#define GST_CAT_DEFAULT gst_multidisksrc_debug
|
||||||
|
|
||||||
GstElementDetails gst_multidisksrc_details = {
|
GstElementDetails gst_multidisksrc_details = {
|
||||||
"Multi Disk Source",
|
"Multi Disk Source",
|
||||||
"Source/File",
|
"Source/File",
|
||||||
|
|
|
@ -28,7 +28,8 @@
|
||||||
|
|
||||||
G_BEGIN_DECLS
|
G_BEGIN_DECLS
|
||||||
|
|
||||||
GstElementDetails gst_multidisksrc_details;
|
extern GstElementDetails gst_multidisksrc_details;
|
||||||
|
GST_DEBUG_CATEGORY_EXTERN(gst_multidisksrc_debug);
|
||||||
|
|
||||||
#define GST_TYPE_MULTIDISKSRC \
|
#define GST_TYPE_MULTIDISKSRC \
|
||||||
(gst_multidisksrc_get_type())
|
(gst_multidisksrc_get_type())
|
||||||
|
|
|
@ -27,10 +27,15 @@
|
||||||
#include <unistd.h>
|
#include <unistd.h>
|
||||||
#include <sys/mman.h>
|
#include <sys/mman.h>
|
||||||
|
|
||||||
/*#define GST_DEBUG_ENABLED*/
|
#ifdef HAVE_CONFIG_H
|
||||||
|
# include "config.h"
|
||||||
|
#endif
|
||||||
|
|
||||||
#include "gstmultidisksrc.h"
|
#include "gstmultidisksrc.h"
|
||||||
|
|
||||||
|
GST_DEBUG_CATEGORY (gst_multidisksrc_debug);
|
||||||
|
#define GST_CAT_DEFAULT gst_multidisksrc_debug
|
||||||
|
|
||||||
GstElementDetails gst_multidisksrc_details = {
|
GstElementDetails gst_multidisksrc_details = {
|
||||||
"Multi Disk Source",
|
"Multi Disk Source",
|
||||||
"Source/File",
|
"Source/File",
|
||||||
|
|
|
@ -28,7 +28,8 @@
|
||||||
|
|
||||||
G_BEGIN_DECLS
|
G_BEGIN_DECLS
|
||||||
|
|
||||||
GstElementDetails gst_multidisksrc_details;
|
extern GstElementDetails gst_multidisksrc_details;
|
||||||
|
GST_DEBUG_CATEGORY_EXTERN(gst_multidisksrc_debug);
|
||||||
|
|
||||||
#define GST_TYPE_MULTIDISKSRC \
|
#define GST_TYPE_MULTIDISKSRC \
|
||||||
(gst_multidisksrc_get_type())
|
(gst_multidisksrc_get_type())
|
||||||
|
|
|
@ -29,9 +29,14 @@
|
||||||
#include <unistd.h>
|
#include <unistd.h>
|
||||||
#include <errno.h>
|
#include <errno.h>
|
||||||
|
|
||||||
/*#define DEBUG_ENABLED*/
|
#ifdef HAVE_CONFIG_H
|
||||||
|
# include "config.h"
|
||||||
|
#endif
|
||||||
|
|
||||||
#include "gstpipefilter.h"
|
#include "gstpipefilter.h"
|
||||||
|
|
||||||
|
GST_DEBUG_CATEGORY (gst_pipefilter_debug);
|
||||||
|
#define GST_CAT_DEFAULT gst_pipefilter_debug
|
||||||
|
|
||||||
GstElementDetails gst_pipefilter_details = {
|
GstElementDetails gst_pipefilter_details = {
|
||||||
"Pipefilter",
|
"Pipefilter",
|
||||||
|
@ -141,7 +146,7 @@ gst_pipefilter_handle_event (GstPad *pad, GstEvent *event)
|
||||||
|
|
||||||
pipefilter = GST_PIPEFILTER (gst_pad_get_parent (pad));
|
pipefilter = GST_PIPEFILTER (gst_pad_get_parent (pad));
|
||||||
|
|
||||||
GST_DEBUG (0,"pipefilter: %s received event", GST_ELEMENT_NAME (pipefilter));
|
GST_DEBUG ("pipefilter: %s received event", GST_ELEMENT_NAME (pipefilter));
|
||||||
if (close (pipefilter->fdin[1]) < 0)
|
if (close (pipefilter->fdin[1]) < 0)
|
||||||
perror("close");
|
perror("close");
|
||||||
if (close (pipefilter->fdout[0]) < 0)
|
if (close (pipefilter->fdout[0]) < 0)
|
||||||
|
@ -169,9 +174,9 @@ gst_pipefilter_get (GstPad *pad)
|
||||||
g_return_val_if_fail(GST_BUFFER_DATA(newbuf) != NULL, NULL);
|
g_return_val_if_fail(GST_BUFFER_DATA(newbuf) != NULL, NULL);
|
||||||
|
|
||||||
/* read it in from the file */
|
/* read it in from the file */
|
||||||
GST_DEBUG (0,"attemting to read %ld bytes", pipefilter->bytes_per_read);
|
GST_DEBUG ("attemting to read %ld bytes", pipefilter->bytes_per_read);
|
||||||
readbytes = read(pipefilter->fdout[0], GST_BUFFER_DATA(newbuf), pipefilter->bytes_per_read);
|
readbytes = read(pipefilter->fdout[0], GST_BUFFER_DATA(newbuf), pipefilter->bytes_per_read);
|
||||||
GST_DEBUG (0,"read %ld bytes", readbytes);
|
GST_DEBUG ("read %ld bytes", readbytes);
|
||||||
if (readbytes < 0) {
|
if (readbytes < 0) {
|
||||||
perror("read");
|
perror("read");
|
||||||
gst_element_error(GST_ELEMENT(pipefilter),"reading");
|
gst_element_error(GST_ELEMENT(pipefilter),"reading");
|
||||||
|
@ -207,9 +212,9 @@ gst_pipefilter_chain (GstPad *pad,GstBuffer *buf)
|
||||||
data = GST_BUFFER_DATA(buf);
|
data = GST_BUFFER_DATA(buf);
|
||||||
size = GST_BUFFER_SIZE(buf);
|
size = GST_BUFFER_SIZE(buf);
|
||||||
|
|
||||||
GST_DEBUG (0,"attemting to write %ld bytes", size);
|
GST_DEBUG ("attemting to write %ld bytes", size);
|
||||||
writebytes = write(pipefilter->fdin[1],data,size);
|
writebytes = write(pipefilter->fdin[1],data,size);
|
||||||
GST_DEBUG (0,"written %ld bytes", writebytes);
|
GST_DEBUG ("written %ld bytes", writebytes);
|
||||||
if (writebytes < 0) {
|
if (writebytes < 0) {
|
||||||
perror("write");
|
perror("write");
|
||||||
gst_element_error(GST_ELEMENT(pipefilter),"writing");
|
gst_element_error(GST_ELEMENT(pipefilter),"writing");
|
||||||
|
|
|
@ -27,11 +27,10 @@
|
||||||
#include <sys/types.h>
|
#include <sys/types.h>
|
||||||
#include <gst/gst.h>
|
#include <gst/gst.h>
|
||||||
|
|
||||||
#include "config.h"
|
|
||||||
|
|
||||||
G_BEGIN_DECLS
|
G_BEGIN_DECLS
|
||||||
|
|
||||||
GstElementDetails gst_pipefilter_details;
|
extern GstElementDetails gst_pipefilter_details;
|
||||||
|
GST_DEBUG_CATEGORY_EXTERN(gst_pipefilter_debug);
|
||||||
|
|
||||||
#define GST_TYPE_PIPEFILTER \
|
#define GST_TYPE_PIPEFILTER \
|
||||||
(gst_pipefilter_get_type())
|
(gst_pipefilter_get_type())
|
||||||
|
|
|
@ -22,7 +22,15 @@
|
||||||
|
|
||||||
|
|
||||||
#include <stdlib.h>
|
#include <stdlib.h>
|
||||||
#include <gstshaper.h>
|
|
||||||
|
#ifdef HAVE_CONFIG_H
|
||||||
|
# include "config.h"
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#include "gstshaper.h"
|
||||||
|
|
||||||
|
GST_DEBUG_CATEGORY (gst_shaper_debug);
|
||||||
|
#define GST_CAT_DEFAULT gst_shaper_debug
|
||||||
|
|
||||||
GstElementDetails gst_shaper_details = {
|
GstElementDetails gst_shaper_details = {
|
||||||
"Shaper",
|
"Shaper",
|
||||||
|
@ -380,4 +388,3 @@ gst_shaper_factory_init (GstElementFactory *factory)
|
||||||
|
|
||||||
return TRUE;
|
return TRUE;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -25,13 +25,12 @@
|
||||||
#define __GST_SHAPER_H__
|
#define __GST_SHAPER_H__
|
||||||
|
|
||||||
|
|
||||||
#include <config.h>
|
|
||||||
#include <gst/gst.h>
|
#include <gst/gst.h>
|
||||||
|
|
||||||
G_BEGIN_DECLS
|
G_BEGIN_DECLS
|
||||||
|
|
||||||
GstElementDetails gst_shaper_details;
|
extern GstElementDetails gst_shaper_details;
|
||||||
|
GST_DEBUG_CATEGORY_EXTERN(gst_shaper_debug);
|
||||||
|
|
||||||
#define GST_TYPE_SHAPER \
|
#define GST_TYPE_SHAPER \
|
||||||
(gst_shaper_get_type())
|
(gst_shaper_get_type())
|
||||||
|
|
|
@ -21,8 +21,14 @@
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
|
||||||
#include <gststatistics.h>
|
#ifdef HAVE_CONFIG_H
|
||||||
|
# include "config.h"
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#include "gststatistics.h"
|
||||||
|
|
||||||
|
GST_DEBUG_CATEGORY (gst_statistics_debug);
|
||||||
|
#define GST_CAT_DEFAULT gst_statistics_debug
|
||||||
|
|
||||||
GstElementDetails gst_statistics_details = {
|
GstElementDetails gst_statistics_details = {
|
||||||
"Statistics",
|
"Statistics",
|
||||||
|
@ -299,9 +305,9 @@ gst_statistics_chain (GstPad *pad, GstBuffer *buf)
|
||||||
|
|
||||||
if (update) {
|
if (update) {
|
||||||
if (statistics->update) {
|
if (statistics->update) {
|
||||||
GST_DEBUG_ELEMENT (GST_CAT_DATAFLOW, statistics, "pre update emit\n");
|
GST_DEBUG ("[%s]: pre update emit", GST_ELEMENT_NAME (statistics));
|
||||||
g_signal_emit (G_OBJECT (statistics), gst_statistics_signals[SIGNAL_UPDATE], 0);
|
g_signal_emit (G_OBJECT (statistics), gst_statistics_signals[SIGNAL_UPDATE], 0);
|
||||||
GST_DEBUG_ELEMENT (GST_CAT_DATAFLOW, statistics, "post update emit\n");
|
GST_DEBUG ("[%s]: post update emit", GST_ELEMENT_NAME (statistics));
|
||||||
}
|
}
|
||||||
if (!statistics->silent) {
|
if (!statistics->silent) {
|
||||||
gst_statistics_print(statistics);
|
gst_statistics_print(statistics);
|
||||||
|
|
|
@ -24,13 +24,12 @@
|
||||||
#define __GST_STATISTICS_H__
|
#define __GST_STATISTICS_H__
|
||||||
|
|
||||||
|
|
||||||
#include <config.h>
|
|
||||||
#include <gst/gst.h>
|
#include <gst/gst.h>
|
||||||
|
|
||||||
G_BEGIN_DECLS
|
G_BEGIN_DECLS
|
||||||
|
|
||||||
GstElementDetails gst_statistics_details;
|
extern GstElementDetails gst_statistics_details;
|
||||||
|
GST_DEBUG_CATEGORY_EXTERN(gst_statistics_debug);
|
||||||
|
|
||||||
#define GST_TYPE_STATISTICS \
|
#define GST_TYPE_STATISTICS \
|
||||||
(gst_statistics_get_type())
|
(gst_statistics_get_type())
|
||||||
|
|
|
@ -20,8 +20,14 @@
|
||||||
* Boston, MA 02111-1307, USA.
|
* Boston, MA 02111-1307, USA.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
#ifdef HAVE_CONFIG_H
|
||||||
|
# include "config.h"
|
||||||
|
#endif
|
||||||
|
|
||||||
#include "gsttee.h"
|
#include "gsttee.h"
|
||||||
|
|
||||||
|
GST_DEBUG_CATEGORY (gst_tee_debug);
|
||||||
|
#define GST_CAT_DEFAULT gst_tee_debug
|
||||||
|
|
||||||
GstElementDetails gst_tee_details = {
|
GstElementDetails gst_tee_details = {
|
||||||
"Tee pipe fitting",
|
"Tee pipe fitting",
|
||||||
|
@ -127,7 +133,7 @@ gst_tee_sinklink (GstPad *pad, GstCaps *caps)
|
||||||
GstPadLinkReturn set_retval;
|
GstPadLinkReturn set_retval;
|
||||||
GstCaps *caps1;
|
GstCaps *caps1;
|
||||||
|
|
||||||
GST_DEBUG (0, "gst_tee_sinklink caps=%s", gst_caps_to_string(caps));
|
GST_DEBUG ( "gst_tee_sinklink caps=%s", gst_caps_to_string(caps));
|
||||||
|
|
||||||
tee = GST_TEE (gst_pad_get_parent (pad));
|
tee = GST_TEE (gst_pad_get_parent (pad));
|
||||||
|
|
||||||
|
@ -162,7 +168,7 @@ gst_tee_srclink (GstPad *pad, GstCaps *caps)
|
||||||
{
|
{
|
||||||
GstTee *tee;
|
GstTee *tee;
|
||||||
|
|
||||||
GST_DEBUG (0, "gst_tee_srclink caps=%s", gst_caps_to_string(caps));
|
GST_DEBUG ( "gst_tee_srclink caps=%s", gst_caps_to_string(caps));
|
||||||
|
|
||||||
tee = GST_TEE (gst_pad_get_parent (pad));
|
tee = GST_TEE (gst_pad_get_parent (pad));
|
||||||
|
|
||||||
|
@ -176,7 +182,7 @@ gst_tee_getcaps (GstPad *pad, GstCaps *filter)
|
||||||
GstTee *tee;
|
GstTee *tee;
|
||||||
const GList *pads;
|
const GList *pads;
|
||||||
|
|
||||||
GST_DEBUG (0, "gst_tee_getcaps");
|
GST_DEBUG ( "gst_tee_getcaps");
|
||||||
|
|
||||||
tee = GST_TEE (gst_pad_get_parent (pad));
|
tee = GST_TEE (gst_pad_get_parent (pad));
|
||||||
|
|
||||||
|
@ -380,4 +386,3 @@ gst_tee_factory_init (GstElementFactory *factory)
|
||||||
|
|
||||||
return TRUE;
|
return TRUE;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -29,6 +29,7 @@
|
||||||
G_BEGIN_DECLS
|
G_BEGIN_DECLS
|
||||||
|
|
||||||
extern GstElementDetails gst_tee_details;
|
extern GstElementDetails gst_tee_details;
|
||||||
|
GST_DEBUG_CATEGORY_EXTERN(gst_tee_debug);
|
||||||
|
|
||||||
#define GST_TYPE_TEE \
|
#define GST_TYPE_TEE \
|
||||||
(gst_tee_get_type())
|
(gst_tee_get_type())
|
||||||
|
|
156
gst/gst.c
156
gst/gst.c
|
@ -35,6 +35,8 @@
|
||||||
#endif /* GST_DISABLE_REGISTRY */
|
#endif /* GST_DISABLE_REGISTRY */
|
||||||
#include "gstregistrypool.h"
|
#include "gstregistrypool.h"
|
||||||
|
|
||||||
|
#define GST_CAT_DEFAULT GST_CAT_GST_INIT
|
||||||
|
|
||||||
#define MAX_PATH_SPLIT 16
|
#define MAX_PATH_SPLIT 16
|
||||||
#define GST_PLUGIN_SEPARATOR ","
|
#define GST_PLUGIN_SEPARATOR ","
|
||||||
|
|
||||||
|
@ -86,10 +88,11 @@ debug_log_handler (const gchar *log_domain,
|
||||||
enum {
|
enum {
|
||||||
ARG_VERSION=1,
|
ARG_VERSION=1,
|
||||||
ARG_FATAL_WARNINGS,
|
ARG_FATAL_WARNINGS,
|
||||||
ARG_INFO_MASK,
|
ARG_DEBUG_LEVEL,
|
||||||
ARG_DEBUG_MASK,
|
ARG_DEBUG,
|
||||||
ARG_MASK,
|
ARG_DEBUG_DISABLE,
|
||||||
ARG_MASK_HELP,
|
ARG_DEBUG_NO_COLOR,
|
||||||
|
ARG_DEBUG_HELP,
|
||||||
ARG_DISABLE_CPU_OPT,
|
ARG_DISABLE_CPU_OPT,
|
||||||
ARG_PLUGIN_SPEW,
|
ARG_PLUGIN_SPEW,
|
||||||
ARG_PLUGIN_PATH,
|
ARG_PLUGIN_PATH,
|
||||||
|
@ -110,10 +113,13 @@ static const struct poptOption gstreamer_options[] = {
|
||||||
{NULL, NUL, POPT_ARG_CALLBACK|POPT_CBFLAG_PRE|POPT_CBFLAG_POST, (void *) &init_popt_callback, 0, NULL, NULL},
|
{NULL, NUL, POPT_ARG_CALLBACK|POPT_CBFLAG_PRE|POPT_CBFLAG_POST, (void *) &init_popt_callback, 0, NULL, NULL},
|
||||||
{"gst-version", NUL, POPT_ARG_NONE|POPT_ARGFLAG_STRIP, NULL, ARG_VERSION, "Print the GStreamer version", NULL},
|
{"gst-version", NUL, POPT_ARG_NONE|POPT_ARGFLAG_STRIP, NULL, ARG_VERSION, "Print the GStreamer version", NULL},
|
||||||
{"gst-fatal-warnings", NUL, POPT_ARG_NONE|POPT_ARGFLAG_STRIP, NULL, ARG_FATAL_WARNINGS, "Make all warnings fatal", NULL},
|
{"gst-fatal-warnings", NUL, POPT_ARG_NONE|POPT_ARGFLAG_STRIP, NULL, ARG_FATAL_WARNINGS, "Make all warnings fatal", NULL},
|
||||||
{"gst-info-mask", NUL, POPT_ARG_INT|POPT_ARGFLAG_STRIP, NULL, ARG_INFO_MASK, "info bitmask", "MASK"},
|
#ifndef GST_DISABLE_GST_DEBUG
|
||||||
{"gst-debug-mask", NUL, POPT_ARG_INT|POPT_ARGFLAG_STRIP, NULL, ARG_DEBUG_MASK, "debugging bitmask", "MASK"},
|
{"gst-debug-level", NUL, POPT_ARG_INT|POPT_ARGFLAG_STRIP, NULL, ARG_DEBUG_LEVEL, "default debug level from 1 (only error) to 5 (anything) or 0 for no output", "LEVEL"},
|
||||||
{"gst-mask", NUL, POPT_ARG_INT|POPT_ARGFLAG_STRIP, NULL, ARG_MASK, "bitmask for both info and debugging", "MASK"},
|
{"gst-debug", NUL, POPT_ARG_STRING|POPT_ARGFLAG_STRIP, NULL, ARG_DEBUG, "colon-seperated list of category=name pairs to use specific levels", "CATEGORIES"},
|
||||||
{"gst-mask-help", NUL, POPT_ARG_NONE|POPT_ARGFLAG_STRIP, NULL, ARG_MASK_HELP, "how to set the level of diagnostic output (-mask values)", NULL},
|
{"gst-debug-no-color", NUL, POPT_ARG_NONE|POPT_ARGFLAG_STRIP, NULL, ARG_DEBUG_NO_COLOR, "disable color debugging output", NULL},
|
||||||
|
{"gst-disable-debug", NUL, POPT_ARG_NONE|POPT_ARGFLAG_STRIP, NULL, ARG_DEBUG_DISABLE, "disable debugging"},
|
||||||
|
{"gst-debug-help", NUL, POPT_ARG_NONE|POPT_ARGFLAG_STRIP, NULL, ARG_DEBUG_HELP, "print available debug categories and exit", NULL},
|
||||||
|
#endif
|
||||||
{"gst-disable-cpu-opt",NUL, POPT_ARG_NONE|POPT_ARGFLAG_STRIP, NULL, ARG_DISABLE_CPU_OPT,"Disable accelerated CPU instructions", NULL},
|
{"gst-disable-cpu-opt",NUL, POPT_ARG_NONE|POPT_ARGFLAG_STRIP, NULL, ARG_DISABLE_CPU_OPT,"Disable accelerated CPU instructions", NULL},
|
||||||
{"gst-plugin-spew", NUL, POPT_ARG_NONE|POPT_ARGFLAG_STRIP, NULL, ARG_PLUGIN_SPEW, "enable verbose plugin loading diagnostics", NULL},
|
{"gst-plugin-spew", NUL, POPT_ARG_NONE|POPT_ARGFLAG_STRIP, NULL, ARG_PLUGIN_SPEW, "enable verbose plugin loading diagnostics", NULL},
|
||||||
{"gst-plugin-path", NUL, POPT_ARG_STRING|POPT_ARGFLAG_STRIP, NULL, ARG_PLUGIN_PATH, "'" G_SEARCHPATH_SEPARATOR_S "'--separated path list for loading plugins", "PATHS"},
|
{"gst-plugin-path", NUL, POPT_ARG_STRING|POPT_ARGFLAG_STRIP, NULL, ARG_PLUGIN_PATH, "'" G_SEARCHPATH_SEPARATOR_S "'--separated path list for loading plugins", "PATHS"},
|
||||||
|
@ -235,7 +241,7 @@ gst_init_check_with_popt_table (int *argc, char **argv[],
|
||||||
|
|
||||||
if (gst_initialized)
|
if (gst_initialized)
|
||||||
{
|
{
|
||||||
GST_DEBUG (GST_CAT_GST_INIT, "already initialized gst\n");
|
GST_DEBUG ("already initialized gst");
|
||||||
return TRUE;
|
return TRUE;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -287,7 +293,7 @@ add_path_func (gpointer data, gpointer user_data)
|
||||||
{
|
{
|
||||||
GstRegistry *registry = GST_REGISTRY (user_data);
|
GstRegistry *registry = GST_REGISTRY (user_data);
|
||||||
|
|
||||||
GST_INFO (GST_CAT_GST_INIT, "Adding plugin path: \"%s\"", (gchar *)data);
|
GST_INFO ("Adding plugin path: \"%s\"", (gchar *) data);
|
||||||
gst_registry_add_path (registry, (gchar *)data);
|
gst_registry_add_path (registry, (gchar *)data);
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
@ -298,6 +304,34 @@ prepare_for_load_plugin_func (gpointer data, gpointer user_data)
|
||||||
preload_plugins = g_slist_prepend (preload_plugins, data);
|
preload_plugins = g_slist_prepend (preload_plugins, data);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static void
|
||||||
|
parse_debug_list (const gchar *list)
|
||||||
|
{
|
||||||
|
gchar **split;
|
||||||
|
gchar **walk;
|
||||||
|
|
||||||
|
g_return_if_fail (list != NULL);
|
||||||
|
|
||||||
|
walk = split = g_strsplit (list, ":", 0);
|
||||||
|
|
||||||
|
while (walk[0]) {
|
||||||
|
gchar **values = g_strsplit ( walk[0], "=", 2);
|
||||||
|
if (values[0] && values[1]) {
|
||||||
|
gint level = 0;
|
||||||
|
g_strstrip (values[0]);
|
||||||
|
g_strstrip (values[1]);
|
||||||
|
level = strtol (values[1], NULL, 0);
|
||||||
|
if (level >= 0 && level < GST_LEVEL_COUNT) {
|
||||||
|
GST_DEBUG ("setting debugging to level %d for name \"%s\"",
|
||||||
|
level, values[0]);
|
||||||
|
gst_debug_set_threshold_for_name (values[0], level);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
g_strfreev (values);
|
||||||
|
walk++;
|
||||||
|
}
|
||||||
|
g_strfreev (split);
|
||||||
|
}
|
||||||
static void
|
static void
|
||||||
load_plugin_func (gpointer data, gpointer user_data)
|
load_plugin_func (gpointer data, gpointer user_data)
|
||||||
{
|
{
|
||||||
|
@ -311,22 +345,16 @@ load_plugin_func (gpointer data, gpointer user_data)
|
||||||
ret = gst_plugin_load_plugin (plugin, NULL);
|
ret = gst_plugin_load_plugin (plugin, NULL);
|
||||||
|
|
||||||
if (ret) {
|
if (ret) {
|
||||||
GST_INFO (GST_CAT_GST_INIT, "Loaded plugin: \"%s\"", filename);
|
GST_INFO ("Loaded plugin: \"%s\"", filename);
|
||||||
|
|
||||||
gst_registry_pool_add_plugin (plugin);
|
gst_registry_pool_add_plugin (plugin);
|
||||||
|
} else {
|
||||||
|
GST_WARNING ("Failed to load plugin: \"%s\"", filename);
|
||||||
}
|
}
|
||||||
else
|
|
||||||
GST_INFO (GST_CAT_GST_INIT, "Failed to load plugin: \"%s\"", filename);
|
|
||||||
|
|
||||||
g_free (data);
|
g_free (data);
|
||||||
}
|
}
|
||||||
|
|
||||||
static void
|
|
||||||
parse_number (const gchar *number, gint32 *val)
|
|
||||||
{
|
|
||||||
*val = strtol(number,NULL,0);
|
|
||||||
}
|
|
||||||
|
|
||||||
static void
|
static void
|
||||||
split_and_iterate (const gchar *stringlist, gchar *separator, GFunc iterator, gpointer user_data)
|
split_and_iterate (const gchar *stringlist, gchar *separator, GFunc iterator, gpointer user_data)
|
||||||
{
|
{
|
||||||
|
@ -355,8 +383,20 @@ split_and_iterate (const gchar *stringlist, gchar *separator, GFunc iterator, gp
|
||||||
static gboolean
|
static gboolean
|
||||||
init_pre (void)
|
init_pre (void)
|
||||||
{
|
{
|
||||||
|
|
||||||
g_type_init ();
|
g_type_init ();
|
||||||
|
|
||||||
|
_gst_debug_init();
|
||||||
|
#ifndef GST_DISABLE_REGISTRY
|
||||||
|
{
|
||||||
|
const gchar *debug_list;
|
||||||
|
|
||||||
|
debug_list = g_getenv ("GST_DEBUG");
|
||||||
|
if (debug_list) {
|
||||||
|
parse_debug_list (debug_list);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
#endif
|
||||||
#ifndef GST_DISABLE_REGISTRY
|
#ifndef GST_DISABLE_REGISTRY
|
||||||
{
|
{
|
||||||
gchar *user_reg;
|
gchar *user_reg;
|
||||||
|
@ -454,9 +494,8 @@ init_post (void)
|
||||||
llf = G_LOG_LEVEL_CRITICAL | G_LOG_LEVEL_ERROR | G_LOG_FLAG_FATAL;
|
llf = G_LOG_LEVEL_CRITICAL | G_LOG_LEVEL_ERROR | G_LOG_FLAG_FATAL;
|
||||||
g_log_set_handler (g_log_domain_gstreamer, llf, debug_log_handler, NULL);
|
g_log_set_handler (g_log_domain_gstreamer, llf, debug_log_handler, NULL);
|
||||||
|
|
||||||
GST_INFO (GST_CAT_GST_INIT,
|
GST_INFO ("Initializing GStreamer Core Library version %s %s",
|
||||||
"Initializing GStreamer Core Library version %s %s",
|
VERSION, _gst_use_threads ? "" : "(no threads)");
|
||||||
GST_VERSION, _gst_use_threads?"":"(no threads)");
|
|
||||||
|
|
||||||
_gst_format_initialize ();
|
_gst_format_initialize ();
|
||||||
_gst_query_type_initialize ();
|
_gst_query_type_initialize ();
|
||||||
|
@ -537,29 +576,39 @@ init_post (void)
|
||||||
}
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
gst_mask_help (void)
|
gst_debug_help (void)
|
||||||
{
|
{
|
||||||
guint i;
|
GSList *cats, *walk;
|
||||||
|
|
||||||
g_print ("\n Mask (to be OR'ed) info/debug FLAGS \n");
|
walk = cats = gst_debug_get_all_categories ();
|
||||||
g_print ("--------------------------------------------------------\n");
|
|
||||||
|
|
||||||
for (i = 0; i<GST_CAT_MAX_CATEGORY; i++) {
|
g_print ("\n");
|
||||||
if (gst_get_category_name(i)) {
|
g_print ("name level description\n");
|
||||||
|
g_print ("---------------------+--------+--------------------------------\n");
|
||||||
|
|
||||||
#if GST_DEBUG_COLOR
|
while (walk) {
|
||||||
g_print (" 0x%08x %s%s \033[%sm%s\033[00m\n", 1<<i,
|
/* unused when debugging is disabled */
|
||||||
(gst_info_get_categories() & (1<<i)?"(enabled)":" "),
|
G_GNUC_UNUSED GstDebugCategory *cat = (GstDebugCategory *) walk->data;
|
||||||
(gst_debug_get_categories() & (1<<i)?"/(enabled)":"/ "),
|
|
||||||
_gst_category_colors[i], gst_get_category_name (i));
|
if (gst_debug_is_colored ()) {
|
||||||
#else
|
gchar *color = gst_debug_construct_term_color (cat->color);
|
||||||
g_print (" 0x%08x %s%s %s\n", 1<<i,
|
g_print ("%s%-20s\033[00m %1d %s %s%s\033[00m\n",
|
||||||
(gst_info_get_categories() & (1<<i)?"(enabled)":" "),
|
color,
|
||||||
(gst_debug_get_categories() & (1<<i)?"/(enabled)":"/ "),
|
gst_debug_category_get_name (cat),
|
||||||
gst_get_category_name (i));
|
gst_debug_category_get_threshold (cat),
|
||||||
#endif
|
gst_debug_level_get_name (gst_debug_category_get_threshold (cat)),
|
||||||
|
color,
|
||||||
|
gst_debug_category_get_description (cat));
|
||||||
|
g_free (color);
|
||||||
|
} else {
|
||||||
|
g_print ("%-20s %1d %s %s\n", gst_debug_category_get_name (cat),
|
||||||
|
gst_debug_category_get_threshold (cat),
|
||||||
|
gst_debug_level_get_name (gst_debug_category_get_threshold (cat)),
|
||||||
|
gst_debug_category_get_description (cat));
|
||||||
}
|
}
|
||||||
|
walk = g_slist_next (walk);
|
||||||
}
|
}
|
||||||
|
g_print ("\n");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@ -567,7 +616,6 @@ static void
|
||||||
init_popt_callback (poptContext context, enum poptCallbackReason reason,
|
init_popt_callback (poptContext context, enum poptCallbackReason reason,
|
||||||
const struct poptOption *option, const char *arg, void *data)
|
const struct poptOption *option, const char *arg, void *data)
|
||||||
{
|
{
|
||||||
gint32 val = 0;
|
|
||||||
GLogLevelFlags fatal_mask;
|
GLogLevelFlags fatal_mask;
|
||||||
|
|
||||||
if (gst_initialized)
|
if (gst_initialized)
|
||||||
|
@ -586,21 +634,25 @@ init_popt_callback (poptContext context, enum poptCallbackReason reason,
|
||||||
fatal_mask |= G_LOG_LEVEL_WARNING | G_LOG_LEVEL_CRITICAL;
|
fatal_mask |= G_LOG_LEVEL_WARNING | G_LOG_LEVEL_CRITICAL;
|
||||||
g_log_set_always_fatal (fatal_mask);
|
g_log_set_always_fatal (fatal_mask);
|
||||||
break;
|
break;
|
||||||
case ARG_INFO_MASK:
|
case ARG_DEBUG_LEVEL: {
|
||||||
parse_number (arg, &val);
|
gint tmp = 0;
|
||||||
gst_info_set_categories ((guint32) val);
|
tmp = strtol (arg, NULL, 0);
|
||||||
|
if (tmp >= 0 && tmp < GST_LEVEL_COUNT) {
|
||||||
|
gst_debug_set_default_threshold (tmp);
|
||||||
|
}
|
||||||
break;
|
break;
|
||||||
case ARG_DEBUG_MASK:
|
}
|
||||||
parse_number (arg, &val);
|
case ARG_DEBUG:
|
||||||
gst_debug_set_categories ((guint32) val);
|
parse_debug_list (arg);
|
||||||
break;
|
break;
|
||||||
case ARG_MASK:
|
case ARG_DEBUG_NO_COLOR:
|
||||||
parse_number (arg, &val);
|
gst_debug_set_colored (FALSE);
|
||||||
gst_debug_set_categories ((guint32) val);
|
|
||||||
gst_info_set_categories ((guint32) val);
|
|
||||||
break;
|
break;
|
||||||
case ARG_MASK_HELP:
|
case ARG_DEBUG_DISABLE:
|
||||||
gst_mask_help ();
|
gst_debug_set_active (FALSE);
|
||||||
|
break;
|
||||||
|
case ARG_DEBUG_HELP:
|
||||||
|
gst_debug_help ();
|
||||||
exit (0);
|
exit (0);
|
||||||
case ARG_DISABLE_CPU_OPT:
|
case ARG_DISABLE_CPU_OPT:
|
||||||
_gst_enable_cpu_opt = FALSE;
|
_gst_enable_cpu_opt = FALSE;
|
||||||
|
|
|
@ -25,7 +25,8 @@
|
||||||
#define __GST_PRIVATE_H__
|
#define __GST_PRIVATE_H__
|
||||||
|
|
||||||
#ifdef HAVE_CONFIG_H
|
#ifdef HAVE_CONFIG_H
|
||||||
#include "config.h"
|
# include "config.h"
|
||||||
|
#endif
|
||||||
|
|
||||||
/***** until we have gettext set up properly, don't even try this*/
|
/***** until we have gettext set up properly, don't even try this*/
|
||||||
#if 0
|
#if 0
|
||||||
|
@ -48,12 +49,44 @@
|
||||||
# endif /* ENABLE_NLS */
|
# endif /* ENABLE_NLS */
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#endif /* HAVE_CONFIG_H */
|
|
||||||
|
|
||||||
|
|
||||||
#include <stdlib.h>
|
#include <stdlib.h>
|
||||||
#include <string.h>
|
#include <string.h>
|
||||||
|
|
||||||
|
/*** debugging categories *****************************************************/
|
||||||
|
|
||||||
|
#ifndef GST_DISABLE_GST_DEBUG
|
||||||
|
|
||||||
#include <gst/gstinfo.h>
|
#include <gst/gstinfo.h>
|
||||||
|
|
||||||
|
extern GstDebugCategory *GST_CAT_GST_INIT;
|
||||||
|
extern GstDebugCategory *GST_CAT_COTHREADS;
|
||||||
|
extern GstDebugCategory *GST_CAT_COTHREAD_SWITCH;
|
||||||
|
extern GstDebugCategory *GST_CAT_AUTOPLUG;
|
||||||
|
extern GstDebugCategory *GST_CAT_AUTOPLUG_ATTEMPT;
|
||||||
|
extern GstDebugCategory *GST_CAT_PARENTAGE;
|
||||||
|
extern GstDebugCategory *GST_CAT_STATES;
|
||||||
|
extern GstDebugCategory *GST_CAT_PLANNING;
|
||||||
|
extern GstDebugCategory *GST_CAT_SCHEDULING;
|
||||||
|
extern GstDebugCategory *GST_CAT_DATAFLOW;
|
||||||
|
extern GstDebugCategory *GST_CAT_BUFFER;
|
||||||
|
extern GstDebugCategory *GST_CAT_CAPS;
|
||||||
|
extern GstDebugCategory *GST_CAT_CLOCK;
|
||||||
|
extern GstDebugCategory *GST_CAT_ELEMENT_PADS;
|
||||||
|
extern GstDebugCategory *GST_CAT_ELEMENT_FACTORY;
|
||||||
|
extern GstDebugCategory *GST_CAT_PADS;
|
||||||
|
extern GstDebugCategory *GST_CAT_PIPELINE;
|
||||||
|
extern GstDebugCategory *GST_CAT_PLUGIN_LOADING;
|
||||||
|
extern GstDebugCategory *GST_CAT_PLUGIN_INFO;
|
||||||
|
extern GstDebugCategory *GST_CAT_PROPERTIES;
|
||||||
|
extern GstDebugCategory *GST_CAT_THREAD;
|
||||||
|
extern GstDebugCategory *GST_CAT_TYPES;
|
||||||
|
extern GstDebugCategory *GST_CAT_XML;
|
||||||
|
extern GstDebugCategory *GST_CAT_NEGOTIATION;
|
||||||
|
extern GstDebugCategory *GST_CAT_REFCOUNTING;
|
||||||
|
extern GstDebugCategory *GST_CAT_EVENT;
|
||||||
|
extern GstDebugCategory *GST_CAT_PARAMS;
|
||||||
|
extern GstDebugCategory *GST_CAT_CALL_TRACE;
|
||||||
|
|
||||||
|
#endif
|
||||||
|
|
||||||
#endif /* __GST_PRIVATE_H__ */
|
#endif /* __GST_PRIVATE_H__ */
|
||||||
|
|
|
@ -20,15 +20,14 @@
|
||||||
* Boston, MA 02111-1307, USA.
|
* Boston, MA 02111-1307, USA.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
/* #define GST_DEBUG_ENABLED */
|
|
||||||
|
|
||||||
#include <gst/gstconfig.h>
|
|
||||||
|
|
||||||
#include "gst_private.h"
|
#include "gst_private.h"
|
||||||
|
|
||||||
|
#include <gst/gstconfig.h>
|
||||||
|
|
||||||
#include "gstautoplug.h"
|
#include "gstautoplug.h"
|
||||||
#include "gstregistrypool.h"
|
#include "gstregistrypool.h"
|
||||||
#include "gstlog.h"
|
#include "gstinfo.h"
|
||||||
|
|
||||||
enum {
|
enum {
|
||||||
NEW_OBJECT,
|
NEW_OBJECT,
|
||||||
|
@ -327,7 +326,7 @@ gst_autoplug_factory_find (const gchar *name)
|
||||||
|
|
||||||
g_return_val_if_fail (name != NULL, NULL);
|
g_return_val_if_fail (name != NULL, NULL);
|
||||||
|
|
||||||
GST_DEBUG (0,"gstautoplug: find \"%s\"", name);
|
GST_DEBUG ("gstautoplug: find \"%s\"", name);
|
||||||
|
|
||||||
feature = gst_registry_pool_find_feature (name, GST_TYPE_AUTOPLUG_FACTORY);
|
feature = gst_registry_pool_find_feature (name, GST_TYPE_AUTOPLUG_FACTORY);
|
||||||
if (feature)
|
if (feature)
|
||||||
|
|
80
gst/gstbin.c
80
gst/gstbin.c
|
@ -21,13 +21,12 @@
|
||||||
* Boston, MA 02111-1307, USA.
|
* Boston, MA 02111-1307, USA.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
/* #define GST_DEBUG_ENABLED */
|
|
||||||
#include "gst_private.h"
|
#include "gst_private.h"
|
||||||
|
|
||||||
#include "gstevent.h"
|
#include "gstevent.h"
|
||||||
#include "gstbin.h"
|
#include "gstbin.h"
|
||||||
#include "gstxml.h"
|
#include "gstxml.h"
|
||||||
#include "gstlog.h"
|
#include "gstinfo.h"
|
||||||
|
|
||||||
#include "gstscheduler.h"
|
#include "gstscheduler.h"
|
||||||
#include "gstindex.h"
|
#include "gstindex.h"
|
||||||
|
@ -258,19 +257,19 @@ gst_bin_set_index (GstElement *element, GstIndex *index)
|
||||||
static void
|
static void
|
||||||
gst_bin_set_element_sched (GstElement *element, GstScheduler *sched)
|
gst_bin_set_element_sched (GstElement *element, GstScheduler *sched)
|
||||||
{
|
{
|
||||||
GST_INFO (GST_CAT_SCHEDULING, "setting element \"%s\" sched to %p", GST_ELEMENT_NAME (element),
|
GST_CAT_INFO (GST_CAT_SCHEDULING, "setting element \"%s\" sched to %p", GST_ELEMENT_NAME (element),
|
||||||
sched);
|
sched);
|
||||||
|
|
||||||
/* if it's actually a Bin */
|
/* if it's actually a Bin */
|
||||||
if (GST_IS_BIN (element)) {
|
if (GST_IS_BIN (element)) {
|
||||||
if (GST_FLAG_IS_SET (element, GST_BIN_FLAG_MANAGER)) {
|
if (GST_FLAG_IS_SET (element, GST_BIN_FLAG_MANAGER)) {
|
||||||
GST_INFO_ELEMENT (GST_CAT_PARENTAGE, element, "child is already a manager, not resetting");
|
GST_CAT_INFO (GST_CAT_PARENTAGE, "[%s]: child is already a manager, not resetting", GST_ELEMENT_NAME (element));
|
||||||
if (GST_ELEMENT_SCHED (element))
|
if (GST_ELEMENT_SCHED (element))
|
||||||
gst_scheduler_add_scheduler (sched, GST_ELEMENT_SCHED (element));
|
gst_scheduler_add_scheduler (sched, GST_ELEMENT_SCHED (element));
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
GST_INFO_ELEMENT (GST_CAT_PARENTAGE, element, "setting children's schedule to parent's");
|
GST_CAT_INFO (GST_CAT_PARENTAGE, "[%s]: setting children's schedule to parent's", GST_ELEMENT_NAME (element));
|
||||||
gst_scheduler_add_element (sched, element);
|
gst_scheduler_add_element (sched, element);
|
||||||
|
|
||||||
/* set the children's schedule */
|
/* set the children's schedule */
|
||||||
|
@ -297,7 +296,7 @@ gst_bin_set_element_sched (GstElement *element, GstScheduler *sched)
|
||||||
/* if the peer element exists and is a candidate */
|
/* if the peer element exists and is a candidate */
|
||||||
if (GST_PAD_PEER (pad)) {
|
if (GST_PAD_PEER (pad)) {
|
||||||
if (gst_pad_get_scheduler (GST_PAD_PEER (pad)) == sched) {
|
if (gst_pad_get_scheduler (GST_PAD_PEER (pad)) == sched) {
|
||||||
GST_INFO (GST_CAT_SCHEDULING,
|
GST_CAT_INFO (GST_CAT_SCHEDULING,
|
||||||
"peer is in same scheduler, telling scheduler");
|
"peer is in same scheduler, telling scheduler");
|
||||||
|
|
||||||
if (GST_PAD_IS_SRC (pad))
|
if (GST_PAD_IS_SRC (pad))
|
||||||
|
@ -315,20 +314,20 @@ static void
|
||||||
gst_bin_unset_element_sched (GstElement *element, GstScheduler *sched)
|
gst_bin_unset_element_sched (GstElement *element, GstScheduler *sched)
|
||||||
{
|
{
|
||||||
if (GST_ELEMENT_SCHED (element) == NULL) {
|
if (GST_ELEMENT_SCHED (element) == NULL) {
|
||||||
GST_INFO (GST_CAT_SCHEDULING, "element \"%s\" has no scheduler",
|
GST_CAT_INFO (GST_CAT_SCHEDULING, "element \"%s\" has no scheduler",
|
||||||
GST_ELEMENT_NAME (element));
|
GST_ELEMENT_NAME (element));
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
GST_INFO (GST_CAT_SCHEDULING, "removing element \"%s\" from its sched %p",
|
GST_CAT_INFO (GST_CAT_SCHEDULING, "removing element \"%s\" from its sched %p",
|
||||||
GST_ELEMENT_NAME (element), GST_ELEMENT_SCHED (element));
|
GST_ELEMENT_NAME (element), GST_ELEMENT_SCHED (element));
|
||||||
|
|
||||||
/* if it's actually a Bin */
|
/* if it's actually a Bin */
|
||||||
if (GST_IS_BIN (element)) {
|
if (GST_IS_BIN (element)) {
|
||||||
|
|
||||||
if (GST_FLAG_IS_SET (element, GST_BIN_FLAG_MANAGER)) {
|
if (GST_FLAG_IS_SET (element, GST_BIN_FLAG_MANAGER)) {
|
||||||
GST_INFO_ELEMENT (GST_CAT_PARENTAGE, element,
|
GST_CAT_INFO (GST_CAT_PARENTAGE, "[%s]: child is already a manager, not unsetting sched",
|
||||||
"child is already a manager, not unsetting sched");
|
GST_ELEMENT_NAME (element));
|
||||||
if (sched) {
|
if (sched) {
|
||||||
gst_scheduler_remove_scheduler (sched, GST_ELEMENT_SCHED (element));
|
gst_scheduler_remove_scheduler (sched, GST_ELEMENT_SCHED (element));
|
||||||
}
|
}
|
||||||
|
@ -358,7 +357,7 @@ gst_bin_unset_element_sched (GstElement *element, GstScheduler *sched)
|
||||||
/* if the peer element exists and is a candidate */
|
/* if the peer element exists and is a candidate */
|
||||||
if (GST_PAD_PEER (pad)) {
|
if (GST_PAD_PEER (pad)) {
|
||||||
if (gst_pad_get_scheduler (GST_PAD_PEER (pad)) == sched) {
|
if (gst_pad_get_scheduler (GST_PAD_PEER (pad)) == sched) {
|
||||||
GST_INFO (GST_CAT_SCHEDULING, "peer is in same scheduler, telling scheduler");
|
GST_CAT_INFO (GST_CAT_SCHEDULING, "peer is in same scheduler, telling scheduler");
|
||||||
|
|
||||||
if (GST_PAD_IS_SRC (pad))
|
if (GST_PAD_IS_SRC (pad))
|
||||||
gst_scheduler_pad_unlink (sched, pad, GST_PAD_PEER (pad));
|
gst_scheduler_pad_unlink (sched, pad, GST_PAD_PEER (pad));
|
||||||
|
@ -437,7 +436,8 @@ gst_bin_add_func (GstBin *bin, GstElement *element)
|
||||||
gst_bin_set_element_sched (element, sched);
|
gst_bin_set_element_sched (element, sched);
|
||||||
}
|
}
|
||||||
|
|
||||||
GST_INFO_ELEMENT (GST_CAT_PARENTAGE, bin, "added child \"%s\"", GST_ELEMENT_NAME (element));
|
GST_CAT_INFO (GST_CAT_PARENTAGE, "[%s]: added child \"%s\"",
|
||||||
|
GST_ELEMENT_NAME (bin), GST_ELEMENT_NAME (element));
|
||||||
|
|
||||||
g_signal_emit (G_OBJECT (bin), gst_bin_signals[ELEMENT_ADDED], 0, element);
|
g_signal_emit (G_OBJECT (bin), gst_bin_signals[ELEMENT_ADDED], 0, element);
|
||||||
}
|
}
|
||||||
|
@ -458,7 +458,7 @@ gst_bin_add (GstBin *bin, GstElement *element)
|
||||||
g_return_if_fail (GST_IS_BIN (bin));
|
g_return_if_fail (GST_IS_BIN (bin));
|
||||||
g_return_if_fail (GST_IS_ELEMENT (element));
|
g_return_if_fail (GST_IS_ELEMENT (element));
|
||||||
|
|
||||||
GST_DEBUG (GST_CAT_PARENTAGE, "adding element \"%s\" to bin \"%s\"",
|
GST_CAT_DEBUG (GST_CAT_PARENTAGE, "adding element \"%s\" to bin \"%s\"",
|
||||||
GST_ELEMENT_NAME (element), GST_ELEMENT_NAME (bin));
|
GST_ELEMENT_NAME (element), GST_ELEMENT_NAME (bin));
|
||||||
|
|
||||||
bclass = GST_BIN_GET_CLASS (bin);
|
bclass = GST_BIN_GET_CLASS (bin);
|
||||||
|
@ -499,7 +499,8 @@ gst_bin_remove_func (GstBin *bin, GstElement *element)
|
||||||
while (state >>= 1) state_idx++;
|
while (state >>= 1) state_idx++;
|
||||||
bin->child_states[state_idx]--;
|
bin->child_states[state_idx]--;
|
||||||
|
|
||||||
GST_INFO_ELEMENT (GST_CAT_PARENTAGE, bin, "removed child %s", GST_ELEMENT_NAME (element));
|
GST_CAT_INFO (GST_CAT_PARENTAGE, "[%s]: removed child %s",
|
||||||
|
GST_ELEMENT_NAME (bin), GST_ELEMENT_NAME (element));
|
||||||
|
|
||||||
/* ref as we're going to emit a signal */
|
/* ref as we're going to emit a signal */
|
||||||
gst_object_ref (GST_OBJECT (element));
|
gst_object_ref (GST_OBJECT (element));
|
||||||
|
@ -532,7 +533,7 @@ gst_bin_remove (GstBin *bin, GstElement *element)
|
||||||
{
|
{
|
||||||
GstBinClass *bclass;
|
GstBinClass *bclass;
|
||||||
|
|
||||||
GST_DEBUG_ELEMENT (GST_CAT_PARENTAGE, bin, "trying to remove child %s", GST_ELEMENT_NAME (element));
|
GST_CAT_DEBUG (GST_CAT_PARENTAGE, "[%s]: trying to remove child %s", GST_ELEMENT_NAME (bin), GST_ELEMENT_NAME (element));
|
||||||
|
|
||||||
g_return_if_fail (GST_IS_BIN (bin));
|
g_return_if_fail (GST_IS_BIN (bin));
|
||||||
g_return_if_fail (GST_IS_ELEMENT (element));
|
g_return_if_fail (GST_IS_ELEMENT (element));
|
||||||
|
@ -594,7 +595,7 @@ gst_bin_child_state_change (GstBin *bin, GstElementState oldstate,
|
||||||
g_return_if_fail (GST_IS_BIN (bin));
|
g_return_if_fail (GST_IS_BIN (bin));
|
||||||
g_return_if_fail (GST_IS_ELEMENT (child));
|
g_return_if_fail (GST_IS_ELEMENT (child));
|
||||||
|
|
||||||
GST_INFO (GST_CAT_STATES, "child %s changed state in bin %s from %s to %s",
|
GST_CAT_INFO (GST_CAT_STATES, "child %s changed state in bin %s from %s to %s",
|
||||||
GST_ELEMENT_NAME (child), GST_ELEMENT_NAME (bin),
|
GST_ELEMENT_NAME (child), GST_ELEMENT_NAME (bin),
|
||||||
gst_element_state_get_name (oldstate), gst_element_state_get_name (newstate));
|
gst_element_state_get_name (oldstate), gst_element_state_get_name (newstate));
|
||||||
|
|
||||||
|
@ -626,7 +627,7 @@ gst_bin_child_state_change_func (GstBin *bin, GstElementState oldstate,
|
||||||
if (bin->child_states[i] != 0) {
|
if (bin->child_states[i] != 0) {
|
||||||
gint state = (1 << i);
|
gint state = (1 << i);
|
||||||
if (GST_STATE (bin) != state) {
|
if (GST_STATE (bin) != state) {
|
||||||
GST_INFO (GST_CAT_STATES, "bin %s need state change to %s",
|
GST_CAT_INFO (GST_CAT_STATES, "bin %s need state change to %s",
|
||||||
GST_ELEMENT_NAME (bin), gst_element_state_get_name (state));
|
GST_ELEMENT_NAME (bin), gst_element_state_get_name (state));
|
||||||
GST_STATE_PENDING (bin) = state;
|
GST_STATE_PENDING (bin) = state;
|
||||||
GST_UNLOCK (bin);
|
GST_UNLOCK (bin);
|
||||||
|
@ -663,19 +664,17 @@ gst_bin_change_state (GstElement * element)
|
||||||
pending = GST_STATE_PENDING (element);
|
pending = GST_STATE_PENDING (element);
|
||||||
transition = GST_STATE_TRANSITION (element);
|
transition = GST_STATE_TRANSITION (element);
|
||||||
|
|
||||||
GST_INFO_ELEMENT (GST_CAT_STATES, element,
|
GST_CAT_INFO (GST_CAT_STATES, "[%s]: changing childrens' state from %s to %s",
|
||||||
"changing childrens' state from %s to %s",
|
GST_ELEMENT_NAME (element),
|
||||||
gst_element_state_get_name (old_state),
|
gst_element_state_get_name (old_state), gst_element_state_get_name (pending));
|
||||||
gst_element_state_get_name (pending));
|
|
||||||
|
|
||||||
if (pending == GST_STATE_VOID_PENDING)
|
if (pending == GST_STATE_VOID_PENDING)
|
||||||
return GST_STATE_SUCCESS;
|
return GST_STATE_SUCCESS;
|
||||||
|
|
||||||
if (old_state == pending)
|
if (old_state == pending)
|
||||||
{
|
{
|
||||||
GST_INFO_ELEMENT (GST_CAT_STATES, element,
|
GST_CAT_INFO (GST_CAT_STATES, "[%s]: old and pending state are both %s, returning",
|
||||||
"old and pending state are both %s, returning",
|
GST_ELEMENT_NAME (element), gst_element_state_get_name (pending));
|
||||||
gst_element_state_get_name (pending));
|
|
||||||
return GST_STATE_SUCCESS;
|
return GST_STATE_SUCCESS;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -694,8 +693,7 @@ gst_bin_change_state (GstElement * element)
|
||||||
|
|
||||||
switch (gst_element_set_state (child, pending)) {
|
switch (gst_element_set_state (child, pending)) {
|
||||||
case GST_STATE_FAILURE:
|
case GST_STATE_FAILURE:
|
||||||
GST_STATE_PENDING (element) = GST_STATE_VOID_PENDING;
|
GST_CAT_DEBUG (GST_CAT_STATES, "child '%s' failed to go to state %d(%s)",
|
||||||
GST_DEBUG (GST_CAT_STATES, "child '%s' failed to go to state %d(%s)",
|
|
||||||
GST_ELEMENT_NAME (child), pending, gst_element_state_get_name (pending));
|
GST_ELEMENT_NAME (child), pending, gst_element_state_get_name (pending));
|
||||||
|
|
||||||
gst_element_set_state (child, old_child_state);
|
gst_element_set_state (child, old_child_state);
|
||||||
|
@ -709,7 +707,7 @@ gst_bin_change_state (GstElement * element)
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case GST_STATE_ASYNC:
|
case GST_STATE_ASYNC:
|
||||||
GST_DEBUG (GST_CAT_STATES, "child '%s' is changing state asynchronously",
|
GST_CAT_DEBUG (GST_CAT_STATES, "child '%s' is changing state asynchronously",
|
||||||
GST_ELEMENT_NAME (child));
|
GST_ELEMENT_NAME (child));
|
||||||
have_async = TRUE;
|
have_async = TRUE;
|
||||||
break;
|
break;
|
||||||
|
@ -718,7 +716,8 @@ gst_bin_change_state (GstElement * element)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
GST_INFO_ELEMENT (GST_CAT_STATES, element, "done changing bin's state from %s to %s, now in %s",
|
GST_CAT_INFO (GST_CAT_STATES, "[%s]: done changing bin's state from %s to %s, now in %s",
|
||||||
|
GST_ELEMENT_NAME (element),
|
||||||
gst_element_state_get_name (old_state),
|
gst_element_state_get_name (old_state),
|
||||||
gst_element_state_get_name (pending),
|
gst_element_state_get_name (pending),
|
||||||
gst_element_state_get_name (GST_STATE (element)));
|
gst_element_state_get_name (GST_STATE (element)));
|
||||||
|
@ -742,7 +741,7 @@ gst_bin_change_state_norecurse (GstBin * bin)
|
||||||
GstElementStateReturn ret;
|
GstElementStateReturn ret;
|
||||||
|
|
||||||
if (parent_class->change_state) {
|
if (parent_class->change_state) {
|
||||||
GST_DEBUG_ELEMENT (GST_CAT_STATES, bin, "setting bin's own state");
|
GST_CAT_DEBUG (GST_CAT_STATES, "[%s]: setting bin's own state", GST_ELEMENT_NAME (bin));
|
||||||
ret = parent_class->change_state (GST_ELEMENT (bin));
|
ret = parent_class->change_state (GST_ELEMENT (bin));
|
||||||
|
|
||||||
return ret;
|
return ret;
|
||||||
|
@ -758,7 +757,7 @@ gst_bin_dispose (GObject * object)
|
||||||
GList *children, *orig;
|
GList *children, *orig;
|
||||||
GstElement *child;
|
GstElement *child;
|
||||||
|
|
||||||
GST_DEBUG (GST_CAT_REFCOUNTING, "dispose");
|
GST_CAT_DEBUG (GST_CAT_REFCOUNTING, "dispose");
|
||||||
|
|
||||||
if (gst_element_get_state (GST_ELEMENT (object)) == GST_STATE_PLAYING)
|
if (gst_element_get_state (GST_ELEMENT (object)) == GST_STATE_PLAYING)
|
||||||
gst_element_set_state (GST_ELEMENT (object), GST_STATE_PAUSED);
|
gst_element_set_state (GST_ELEMENT (object), GST_STATE_PAUSED);
|
||||||
|
@ -798,7 +797,8 @@ gst_bin_get_by_name (GstBin * bin, const gchar * name)
|
||||||
g_return_val_if_fail (GST_IS_BIN (bin), NULL);
|
g_return_val_if_fail (GST_IS_BIN (bin), NULL);
|
||||||
g_return_val_if_fail (name != NULL, NULL);
|
g_return_val_if_fail (name != NULL, NULL);
|
||||||
|
|
||||||
GST_INFO_ELEMENT (GST_CAT_PARENTAGE, bin, "looking up child element %s", name);
|
GST_CAT_INFO (GST_CAT_PARENTAGE, "[%s]: looking up child element %s",
|
||||||
|
GST_ELEMENT_NAME (bin), name);
|
||||||
|
|
||||||
children = bin->children;
|
children = bin->children;
|
||||||
while (children) {
|
while (children) {
|
||||||
|
@ -890,7 +890,7 @@ gst_bin_sync_children_state (GstBin *bin)
|
||||||
|
|
||||||
state = GST_STATE (bin);
|
state = GST_STATE (bin);
|
||||||
children = bin->children;
|
children = bin->children;
|
||||||
GST_INFO (GST_CAT_STATES, "syncing state of children with bin \"%s\"'s state %s",
|
GST_CAT_INFO (GST_CAT_STATES, "syncing state of children with bin \"%s\"'s state %s",
|
||||||
GST_ELEMENT_NAME (bin), gst_element_state_get_name (state));
|
GST_ELEMENT_NAME (bin), gst_element_state_get_name (state));
|
||||||
|
|
||||||
while (children) {
|
while (children) {
|
||||||
|
@ -929,7 +929,8 @@ gst_bin_save_thyself (GstObject * object, xmlNodePtr parent)
|
||||||
|
|
||||||
childlist = xmlNewChild (parent, NULL, "children", NULL);
|
childlist = xmlNewChild (parent, NULL, "children", NULL);
|
||||||
|
|
||||||
GST_INFO_ELEMENT (GST_CAT_XML, bin, "saving %d children", bin->numchildren);
|
GST_CAT_INFO (GST_CAT_XML, "[%s]: saving %d children",
|
||||||
|
GST_ELEMENT_NAME (bin), bin->numchildren);
|
||||||
|
|
||||||
children = bin->children;
|
children = bin->children;
|
||||||
while (children) {
|
while (children) {
|
||||||
|
@ -950,7 +951,7 @@ gst_bin_restore_thyself (GstObject * object, xmlNodePtr self)
|
||||||
|
|
||||||
while (field) {
|
while (field) {
|
||||||
if (!strcmp (field->name, "children")) {
|
if (!strcmp (field->name, "children")) {
|
||||||
GST_INFO_ELEMENT (GST_CAT_XML, GST_ELEMENT (object), "loading children");
|
GST_CAT_INFO (GST_CAT_XML, "[%s]: loading children", GST_ELEMENT_NAME (object));
|
||||||
childlist = field->xmlChildrenNode;
|
childlist = field->xmlChildrenNode;
|
||||||
while (childlist) {
|
while (childlist) {
|
||||||
if (!strcmp (childlist->name, "element")) {
|
if (!strcmp (childlist->name, "element")) {
|
||||||
|
@ -1012,7 +1013,7 @@ gst_bin_iterate (GstBin *bin)
|
||||||
GstBinClass *oclass;
|
GstBinClass *oclass;
|
||||||
gboolean running = TRUE;
|
gboolean running = TRUE;
|
||||||
|
|
||||||
GST_DEBUG_ENTER ("(\"%s\")", GST_ELEMENT_NAME (bin));
|
GST_CAT_LOG_OBJECT (GST_CAT_DATAFLOW, bin, "starting iteration");
|
||||||
|
|
||||||
g_return_val_if_fail (bin != NULL, FALSE);
|
g_return_val_if_fail (bin != NULL, FALSE);
|
||||||
g_return_val_if_fail (GST_IS_BIN (bin), FALSE);
|
g_return_val_if_fail (GST_IS_BIN (bin), FALSE);
|
||||||
|
@ -1030,15 +1031,14 @@ gst_bin_iterate (GstBin *bin)
|
||||||
if (bin->post_iterate_func)
|
if (bin->post_iterate_func)
|
||||||
(bin->post_iterate_func) (bin, bin->post_iterate_data);
|
(bin->post_iterate_func) (bin, bin->post_iterate_data);
|
||||||
|
|
||||||
GST_DEBUG_LEAVE ("(\"%s\") %d", GST_ELEMENT_NAME (bin), running);
|
GST_CAT_LOG_OBJECT (GST_CAT_DATAFLOW, bin, "finished iteration");
|
||||||
|
|
||||||
if (!running) {
|
if (!running) {
|
||||||
if (GST_STATE (bin) == GST_STATE_PLAYING &&
|
if (GST_STATE (bin) == GST_STATE_PLAYING &&
|
||||||
GST_STATE_PENDING (bin) == GST_STATE_VOID_PENDING) {
|
GST_STATE_PENDING (bin) == GST_STATE_VOID_PENDING) {
|
||||||
GST_DEBUG_ELEMENT (GST_CAT_DATAFLOW, bin,
|
GST_CAT_DEBUG (GST_CAT_DATAFLOW, "[%s]: polling for child shutdown after useless iteration",
|
||||||
"polling for child shutdown after useless iteration");
|
GST_ELEMENT_NAME (bin));
|
||||||
usleep (1);
|
g_usleep (1);
|
||||||
//gst_element_wait_state_change (GST_ELEMENT (bin));
|
|
||||||
running = TRUE;
|
running = TRUE;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -20,15 +20,13 @@
|
||||||
* Boston, MA 02111-1307, USA.
|
* Boston, MA 02111-1307, USA.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
/* this file makes too much noise for most debugging sessions */
|
|
||||||
#define GST_DEBUG_FORCE_DISABLE
|
|
||||||
#include "gst_private.h"
|
#include "gst_private.h"
|
||||||
|
|
||||||
#include "gstatomic_impl.h"
|
#include "gstatomic_impl.h"
|
||||||
#include "gstdata_private.h"
|
#include "gstdata_private.h"
|
||||||
#include "gstbuffer.h"
|
#include "gstbuffer.h"
|
||||||
#include "gstmemchunk.h"
|
#include "gstmemchunk.h"
|
||||||
#include "gstlog.h"
|
#include "gstinfo.h"
|
||||||
#include "gstbufferpool-default.h"
|
#include "gstbufferpool-default.h"
|
||||||
|
|
||||||
GType _gst_buffer_type;
|
GType _gst_buffer_type;
|
||||||
|
@ -63,7 +61,7 @@ _gst_buffer_initialize (void)
|
||||||
chunk = gst_mem_chunk_new ("GstBufferChunk", sizeof (GstBuffer),
|
chunk = gst_mem_chunk_new ("GstBufferChunk", sizeof (GstBuffer),
|
||||||
sizeof (GstBuffer) * 200, 0);
|
sizeof (GstBuffer) * 200, 0);
|
||||||
|
|
||||||
GST_INFO (GST_CAT_BUFFER, "Buffers are initialized now");
|
GST_CAT_INFO (GST_CAT_BUFFER, "Buffers are initialized now");
|
||||||
}
|
}
|
||||||
|
|
||||||
GType
|
GType
|
||||||
|
@ -192,7 +190,7 @@ gst_buffer_new (void)
|
||||||
gst_alloc_trace_new (_gst_buffer_trace, newbuf);
|
gst_alloc_trace_new (_gst_buffer_trace, newbuf);
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
GST_DEBUG (GST_CAT_BUFFER, "new %p", newbuf);
|
GST_CAT_LOG (GST_CAT_BUFFER, "new %p", newbuf);
|
||||||
|
|
||||||
_GST_DATA_INIT (GST_DATA (newbuf),
|
_GST_DATA_INIT (GST_DATA (newbuf),
|
||||||
_gst_buffer_type,
|
_gst_buffer_type,
|
||||||
|
@ -312,7 +310,7 @@ gst_buffer_create_sub (GstBuffer *parent, guint offset, guint size)
|
||||||
gst_alloc_trace_new (_gst_buffer_trace, buffer);
|
gst_alloc_trace_new (_gst_buffer_trace, buffer);
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
GST_DEBUG (GST_CAT_BUFFER, "new %p", buf);
|
GST_CAT_LOG (GST_CAT_BUFFER, "new subbuffer %p", buffer);
|
||||||
|
|
||||||
/* make sure nobody overwrites data in the new buffer
|
/* make sure nobody overwrites data in the new buffer
|
||||||
* by setting the READONLY flag */
|
* by setting the READONLY flag */
|
||||||
|
@ -435,7 +433,7 @@ gst_buffer_span (GstBuffer *buf1, guint32 offset, GstBuffer *buf2, guint32 len)
|
||||||
buf1->data - parent->data + offset, len);
|
buf1->data - parent->data + offset, len);
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
GST_DEBUG (GST_CAT_BUFFER, "slow path taken while spanning buffers %p and %p",
|
GST_CAT_DEBUG (GST_CAT_BUFFER, "slow path taken while spanning buffers %p and %p",
|
||||||
buf1, buf2);
|
buf1, buf2);
|
||||||
/* otherwise we simply have to brute-force copy the buffers */
|
/* otherwise we simply have to brute-force copy the buffers */
|
||||||
newbuf = gst_buffer_new_and_alloc (len);
|
newbuf = gst_buffer_new_and_alloc (len);
|
||||||
|
@ -524,7 +522,7 @@ gst_buffer_pool_new (GstDataFreeFunction free,
|
||||||
gst_alloc_trace_new (_gst_buffer_pool_trace, pool);
|
gst_alloc_trace_new (_gst_buffer_pool_trace, pool);
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
GST_DEBUG (GST_CAT_BUFFER, "allocating new buffer pool %p\n", pool);
|
GST_CAT_DEBUG (GST_CAT_BUFFER, "allocating new buffer pool %p\n", pool);
|
||||||
|
|
||||||
/* init data struct */
|
/* init data struct */
|
||||||
_GST_DATA_INIT (GST_DATA (pool),
|
_GST_DATA_INIT (GST_DATA (pool),
|
||||||
|
|
|
@ -20,11 +20,12 @@
|
||||||
* Boston, MA 02111-1307, USA.
|
* Boston, MA 02111-1307, USA.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
#include "gst_private.h"
|
||||||
|
|
||||||
#include "gstbuffer.h"
|
#include "gstbuffer.h"
|
||||||
#include "gstinfo.h"
|
#include "gstinfo.h"
|
||||||
#include "gstmemchunk.h"
|
#include "gstmemchunk.h"
|
||||||
|
|
||||||
|
|
||||||
/* methods prefixed with underscores to avoid namespace collisions with
|
/* methods prefixed with underscores to avoid namespace collisions with
|
||||||
* gstbuffer.c */
|
* gstbuffer.c */
|
||||||
|
|
||||||
|
@ -106,7 +107,7 @@ gst_buffer_pool_get_default (guint buffer_size, guint pool_size)
|
||||||
g_hash_table_insert (_default_pools, GINT_TO_POINTER (real_buffer_size), pool);
|
g_hash_table_insert (_default_pools, GINT_TO_POINTER (real_buffer_size), pool);
|
||||||
g_mutex_unlock (_default_pool_lock);
|
g_mutex_unlock (_default_pool_lock);
|
||||||
|
|
||||||
GST_DEBUG (GST_CAT_BUFFER,"new default buffer pool %p bytes:%d size:%d",
|
GST_CAT_DEBUG (GST_CAT_BUFFER,"new default buffer pool %p bytes:%d size:%d",
|
||||||
pool, real_buffer_size, pool_size);
|
pool, real_buffer_size, pool_size);
|
||||||
|
|
||||||
return pool;
|
return pool;
|
||||||
|
@ -121,7 +122,7 @@ _gst_buffer_pool_default_buffer_new (GstBufferPool *pool, guint64 offset,
|
||||||
GstMemChunk *data_chunk = def->mem_chunk;
|
GstMemChunk *data_chunk = def->mem_chunk;
|
||||||
|
|
||||||
buffer = gst_buffer_new ();
|
buffer = gst_buffer_new ();
|
||||||
GST_INFO (GST_CAT_BUFFER, "creating new buffer %p from pool %p", buffer, pool);
|
GST_CAT_INFO (GST_CAT_BUFFER, "creating new buffer %p from pool %p", buffer, pool);
|
||||||
|
|
||||||
GST_BUFFER_DATA (buffer) = gst_mem_chunk_alloc (data_chunk);
|
GST_BUFFER_DATA (buffer) = gst_mem_chunk_alloc (data_chunk);
|
||||||
|
|
||||||
|
@ -155,7 +156,7 @@ _gst_buffer_pool_default_free (GstData *data)
|
||||||
|
|
||||||
real_buffer_size = (((def->size-1) / 32) + 1) * 32;
|
real_buffer_size = (((def->size-1) / 32) + 1) * 32;
|
||||||
|
|
||||||
GST_DEBUG (GST_CAT_BUFFER,"destroying default buffer pool %p bytes:%d size:%d",
|
GST_CAT_DEBUG (GST_CAT_BUFFER,"destroying default buffer pool %p bytes:%d size:%d",
|
||||||
pool, real_buffer_size, def->size);
|
pool, real_buffer_size, def->size);
|
||||||
|
|
||||||
g_mutex_lock (_default_pool_lock);
|
g_mutex_lock (_default_pool_lock);
|
||||||
|
|
|
@ -25,7 +25,7 @@
|
||||||
#include "gstcaps.h"
|
#include "gstcaps.h"
|
||||||
#include "gsttype.h"
|
#include "gsttype.h"
|
||||||
#include "gstmemchunk.h"
|
#include "gstmemchunk.h"
|
||||||
#include "gstlog.h"
|
#include "gstinfo.h"
|
||||||
|
|
||||||
#ifndef GST_DISABLE_TRACE
|
#ifndef GST_DISABLE_TRACE
|
||||||
/* #define GST_WITH_ALLOC_TRACE */
|
/* #define GST_WITH_ALLOC_TRACE */
|
||||||
|
@ -253,7 +253,7 @@ gst_caps_new_id (const gchar *name, const guint16 id, GstProps *props)
|
||||||
gst_alloc_trace_new (_gst_caps_trace, caps);
|
gst_alloc_trace_new (_gst_caps_trace, caps);
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
GST_DEBUG (GST_CAT_CAPS, "new %p, props %p", caps, props);
|
GST_CAT_LOG (GST_CAT_CAPS, "new %p, props %p", caps, props);
|
||||||
|
|
||||||
gst_props_ref (props);
|
gst_props_ref (props);
|
||||||
gst_props_sink (props);
|
gst_props_sink (props);
|
||||||
|
@ -318,7 +318,7 @@ gst_caps_destroy (GstCaps *caps)
|
||||||
|
|
||||||
next = caps->next;
|
next = caps->next;
|
||||||
|
|
||||||
GST_DEBUG (GST_CAT_CAPS, "destroy %p", caps);
|
GST_CAT_LOG (GST_CAT_CAPS, "destroy %p", caps);
|
||||||
|
|
||||||
gst_props_unref (caps->properties);
|
gst_props_unref (caps->properties);
|
||||||
g_free (caps->name);
|
g_free (caps->name);
|
||||||
|
@ -342,10 +342,14 @@ gst_caps_destroy (GstCaps *caps)
|
||||||
void
|
void
|
||||||
gst_caps_debug (GstCaps *caps, const gchar *label)
|
gst_caps_debug (GstCaps *caps, const gchar *label)
|
||||||
{
|
{
|
||||||
GST_DEBUG_ENTER ("caps debug: %s", label);
|
GST_CAT_DEBUG (GST_CAT_CAPS, "starting caps debug: %s", label);
|
||||||
|
if (caps && caps->refcount == 0) {
|
||||||
|
g_warning ("Warning: refcount of caps %s is 0", label);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
while (caps) {
|
while (caps) {
|
||||||
GST_DEBUG (GST_CAT_CAPS, "caps: %p %s %s (%sfixed) (refcount %d) %s",
|
GST_CAT_DEBUG (GST_CAT_CAPS, "caps: %p %s %s (%sfixed) (refcount %d) %s",
|
||||||
caps, caps->name, gst_caps_get_mime (caps),
|
caps, caps->name, gst_caps_get_mime (caps),
|
||||||
GST_CAPS_IS_FIXED (caps) ? "" : "NOT ", caps->refcount,
|
GST_CAPS_IS_FIXED (caps) ? "" : "NOT ", caps->refcount,
|
||||||
GST_CAPS_IS_FLOATING (caps) ? "FLOATING" : "");
|
GST_CAPS_IS_FLOATING (caps) ? "FLOATING" : "");
|
||||||
|
@ -354,12 +358,12 @@ gst_caps_debug (GstCaps *caps, const gchar *label)
|
||||||
gst_props_debug (caps->properties);
|
gst_props_debug (caps->properties);
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
GST_DEBUG (GST_CAT_CAPS, "no properties");
|
GST_CAT_DEBUG (GST_CAT_CAPS, "no properties");
|
||||||
}
|
}
|
||||||
|
|
||||||
caps = caps->next;
|
caps = caps->next;
|
||||||
}
|
}
|
||||||
GST_DEBUG_LEAVE ("caps debug");
|
GST_CAT_DEBUG (GST_CAT_CAPS, "finished caps debug");
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -381,7 +385,7 @@ gst_caps_unref (GstCaps *caps)
|
||||||
|
|
||||||
g_return_val_if_fail (caps->refcount > 0, NULL);
|
g_return_val_if_fail (caps->refcount > 0, NULL);
|
||||||
|
|
||||||
GST_DEBUG (GST_CAT_CAPS, "unref %p (%d->%d) %d",
|
GST_CAT_LOG (GST_CAT_CAPS, "unref %p (%d->%d) %d",
|
||||||
caps, caps->refcount, caps->refcount-1, GST_CAPS_FLAGS (caps));
|
caps, caps->refcount, caps->refcount-1, GST_CAPS_FLAGS (caps));
|
||||||
|
|
||||||
caps->refcount--;
|
caps->refcount--;
|
||||||
|
@ -410,7 +414,7 @@ gst_caps_ref (GstCaps *caps)
|
||||||
|
|
||||||
g_return_val_if_fail (caps->refcount > 0, NULL);
|
g_return_val_if_fail (caps->refcount > 0, NULL);
|
||||||
|
|
||||||
GST_DEBUG (GST_CAT_CAPS, "ref %p (%d->%d) %d",
|
GST_CAT_LOG (GST_CAT_CAPS, "ref %p (%d->%d) %d",
|
||||||
caps, caps->refcount, caps->refcount+1, GST_CAPS_FLAGS (caps));
|
caps, caps->refcount, caps->refcount+1, GST_CAPS_FLAGS (caps));
|
||||||
|
|
||||||
caps->refcount++;
|
caps->refcount++;
|
||||||
|
@ -431,7 +435,7 @@ gst_caps_sink (GstCaps *caps)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
if (GST_CAPS_IS_FLOATING (caps)) {
|
if (GST_CAPS_IS_FLOATING (caps)) {
|
||||||
GST_DEBUG (GST_CAT_CAPS, "sink %p", caps);
|
GST_CAT_LOG (GST_CAT_CAPS, "sink %p", caps);
|
||||||
|
|
||||||
GST_CAPS_FLAG_UNSET (caps, GST_CAPS_FLOATING);
|
GST_CAPS_FLAG_UNSET (caps, GST_CAPS_FLOATING);
|
||||||
gst_caps_unref (caps);
|
gst_caps_unref (caps);
|
||||||
|
@ -785,7 +789,7 @@ static gboolean
|
||||||
gst_caps_check_compatibility_func (GstCaps *fromcaps, GstCaps *tocaps)
|
gst_caps_check_compatibility_func (GstCaps *fromcaps, GstCaps *tocaps)
|
||||||
{
|
{
|
||||||
if (fromcaps->id != tocaps->id) {
|
if (fromcaps->id != tocaps->id) {
|
||||||
GST_DEBUG (GST_CAT_CAPS,"mime types differ (%s to %s)",
|
GST_CAT_DEBUG (GST_CAT_CAPS,"mime types differ (%s to %s)",
|
||||||
gst_type_find_by_id (fromcaps->id)->mime,
|
gst_type_find_by_id (fromcaps->id)->mime,
|
||||||
gst_type_find_by_id (tocaps->id)->mime);
|
gst_type_find_by_id (tocaps->id)->mime);
|
||||||
return FALSE;
|
return FALSE;
|
||||||
|
@ -796,13 +800,13 @@ gst_caps_check_compatibility_func (GstCaps *fromcaps, GstCaps *tocaps)
|
||||||
return gst_props_check_compatibility (fromcaps->properties, tocaps->properties);
|
return gst_props_check_compatibility (fromcaps->properties, tocaps->properties);
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
GST_DEBUG (GST_CAT_CAPS,"no source caps");
|
GST_CAT_DEBUG (GST_CAT_CAPS,"no source caps");
|
||||||
return FALSE;
|
return FALSE;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
/* assume it accepts everything */
|
/* assume it accepts everything */
|
||||||
GST_DEBUG (GST_CAT_CAPS,"no caps");
|
GST_CAT_DEBUG (GST_CAT_CAPS,"no caps");
|
||||||
return TRUE;
|
return TRUE;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -823,13 +827,13 @@ gst_caps_is_always_compatible (GstCaps *fromcaps, GstCaps *tocaps)
|
||||||
if (fromcaps == NULL) {
|
if (fromcaps == NULL) {
|
||||||
if (tocaps == NULL) {
|
if (tocaps == NULL) {
|
||||||
/* if both are NULL, they can always link. Think filesrc ! filesink */
|
/* if both are NULL, they can always link. Think filesrc ! filesink */
|
||||||
GST_DEBUG (GST_CAT_CAPS, "both caps NULL, compatible");
|
GST_CAT_DEBUG (GST_CAT_CAPS, "both caps NULL, compatible");
|
||||||
return TRUE;
|
return TRUE;
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
/* if source caps are NULL, it could be sending anything, so the
|
/* if source caps are NULL, it could be sending anything, so the
|
||||||
* destination can't know if it can accept this. Think filesrc ! mad */
|
* destination can't know if it can accept this. Think filesrc ! mad */
|
||||||
GST_DEBUG (GST_CAT_CAPS, "source caps NULL, not guaranteed compatible");
|
GST_CAT_DEBUG (GST_CAT_CAPS, "source caps NULL, not guaranteed compatible");
|
||||||
return FALSE;
|
return FALSE;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -837,7 +841,7 @@ gst_caps_is_always_compatible (GstCaps *fromcaps, GstCaps *tocaps)
|
||||||
if (tocaps == NULL) {
|
if (tocaps == NULL) {
|
||||||
/* if the dest caps are NULL, the element can accept anything, always,
|
/* if the dest caps are NULL, the element can accept anything, always,
|
||||||
* so they're compatible by definition. Think mad ! filesink */
|
* so they're compatible by definition. Think mad ! filesink */
|
||||||
GST_DEBUG (GST_CAT_CAPS,"destination caps NULL");
|
GST_CAT_DEBUG (GST_CAT_CAPS,"destination caps NULL");
|
||||||
return TRUE;
|
return TRUE;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -868,7 +872,7 @@ gst_caps_intersect_func (GstCaps *caps1, GstCaps *caps2)
|
||||||
GstProps *props;
|
GstProps *props;
|
||||||
|
|
||||||
if (caps1->id != caps2->id) {
|
if (caps1->id != caps2->id) {
|
||||||
GST_DEBUG (GST_CAT_CAPS, "mime types differ (%s to %s)",
|
GST_CAT_DEBUG (GST_CAT_CAPS, "mime types differ (%s to %s)",
|
||||||
gst_type_find_by_id (caps1->id)->mime,
|
gst_type_find_by_id (caps1->id)->mime,
|
||||||
gst_type_find_by_id (caps2->id)->mime);
|
gst_type_find_by_id (caps2->id)->mime);
|
||||||
return NULL;
|
return NULL;
|
||||||
|
@ -907,14 +911,14 @@ gst_caps_intersect (GstCaps *caps1, GstCaps *caps2)
|
||||||
GstCaps *result = NULL, *walk = NULL;
|
GstCaps *result = NULL, *walk = NULL;
|
||||||
|
|
||||||
/* printing the name is not useful here since caps can be chained */
|
/* printing the name is not useful here since caps can be chained */
|
||||||
GST_DEBUG (GST_CAT_CAPS, "intersecting caps %p and %p", caps1, caps2);
|
GST_CAT_DEBUG (GST_CAT_CAPS, "intersecting caps %p and %p", caps1, caps2);
|
||||||
|
|
||||||
if (caps1 == NULL) {
|
if (caps1 == NULL) {
|
||||||
GST_DEBUG (GST_CAT_CAPS, "first caps is NULL, return other caps");
|
GST_CAT_DEBUG (GST_CAT_CAPS, "first caps is NULL, return other caps");
|
||||||
return gst_caps_ref (caps2);
|
return gst_caps_ref (caps2);
|
||||||
}
|
}
|
||||||
if (caps2 == NULL) {
|
if (caps2 == NULL) {
|
||||||
GST_DEBUG (GST_CAT_CAPS, "second caps is NULL, return other caps");
|
GST_CAT_DEBUG (GST_CAT_CAPS, "second caps is NULL, return other caps");
|
||||||
return gst_caps_ref (caps1);
|
return gst_caps_ref (caps1);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -953,14 +957,14 @@ gst_caps_union (GstCaps *caps1, GstCaps *caps2)
|
||||||
GstCaps *result = NULL;
|
GstCaps *result = NULL;
|
||||||
|
|
||||||
/* printing the name is not useful here since caps can be chained */
|
/* printing the name is not useful here since caps can be chained */
|
||||||
GST_DEBUG (GST_CAT_CAPS, "making union of caps %p and %p", caps1, caps2);
|
GST_CAT_DEBUG (GST_CAT_CAPS, "making union of caps %p and %p", caps1, caps2);
|
||||||
|
|
||||||
if (caps1 == NULL) {
|
if (caps1 == NULL) {
|
||||||
GST_DEBUG (GST_CAT_CAPS, "first caps is NULL, return other caps");
|
GST_CAT_DEBUG (GST_CAT_CAPS, "first caps is NULL, return other caps");
|
||||||
return gst_caps_ref (caps2);
|
return gst_caps_ref (caps2);
|
||||||
}
|
}
|
||||||
if (caps2 == NULL) {
|
if (caps2 == NULL) {
|
||||||
GST_DEBUG (GST_CAT_CAPS, "second caps is NULL, return other caps");
|
GST_CAT_DEBUG (GST_CAT_CAPS, "second caps is NULL, return other caps");
|
||||||
return gst_caps_ref (caps1);
|
return gst_caps_ref (caps1);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -986,7 +990,7 @@ gst_caps_normalize (GstCaps *caps)
|
||||||
if (caps == NULL)
|
if (caps == NULL)
|
||||||
return caps;
|
return caps;
|
||||||
|
|
||||||
GST_DEBUG (GST_CAT_CAPS, "normalizing caps %p ", caps);
|
GST_CAT_DEBUG (GST_CAT_CAPS, "normalizing caps %p ", caps);
|
||||||
|
|
||||||
walk = caps;
|
walk = caps;
|
||||||
|
|
||||||
|
|
|
@ -23,8 +23,9 @@
|
||||||
#include <sys/time.h>
|
#include <sys/time.h>
|
||||||
|
|
||||||
#include "gst_private.h"
|
#include "gst_private.h"
|
||||||
|
|
||||||
#include "gstclock.h"
|
#include "gstclock.h"
|
||||||
#include "gstlog.h"
|
#include "gstinfo.h"
|
||||||
#include "gstmemchunk.h"
|
#include "gstmemchunk.h"
|
||||||
|
|
||||||
#ifndef GST_DISABLE_TRACE
|
#ifndef GST_DISABLE_TRACE
|
||||||
|
@ -166,7 +167,7 @@ gst_clock_id_wait (GstClockID id, GstClockTimeDiff *jitter)
|
||||||
requested = GST_CLOCK_ENTRY_TIME (entry);
|
requested = GST_CLOCK_ENTRY_TIME (entry);
|
||||||
|
|
||||||
if (! GST_CLOCK_TIME_IS_VALID (requested)) {
|
if (! GST_CLOCK_TIME_IS_VALID (requested)) {
|
||||||
GST_DEBUG (GST_CAT_CLOCK, "invalid time requested, returning _TIMEOUT");
|
GST_CAT_DEBUG (GST_CAT_CLOCK, "invalid time requested, returning _TIMEOUT");
|
||||||
return GST_CLOCK_TIMEOUT;
|
return GST_CLOCK_TIMEOUT;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -180,12 +181,12 @@ gst_clock_id_wait (GstClockID id, GstClockTimeDiff *jitter)
|
||||||
clock->entries = g_list_prepend (clock->entries, entry);
|
clock->entries = g_list_prepend (clock->entries, entry);
|
||||||
GST_UNLOCK (clock);
|
GST_UNLOCK (clock);
|
||||||
|
|
||||||
GST_DEBUG (GST_CAT_CLOCK, "waiting on clock");
|
GST_CAT_DEBUG (GST_CAT_CLOCK, "waiting on clock");
|
||||||
do {
|
do {
|
||||||
res = cclass->wait (clock, entry);
|
res = cclass->wait (clock, entry);
|
||||||
}
|
}
|
||||||
while (res == GST_CLOCK_ENTRY_RESTART);
|
while (res == GST_CLOCK_ENTRY_RESTART);
|
||||||
GST_DEBUG (GST_CAT_CLOCK, "done waiting");
|
GST_CAT_DEBUG (GST_CAT_CLOCK, "done waiting");
|
||||||
|
|
||||||
GST_LOCK (clock);
|
GST_LOCK (clock);
|
||||||
clock->entries = g_list_remove (clock->entries, entry);
|
clock->entries = g_list_remove (clock->entries, entry);
|
||||||
|
@ -600,7 +601,7 @@ gst_clock_handle_discont (GstClock *clock, guint64 time)
|
||||||
{
|
{
|
||||||
GstClockTime itime = G_GINT64_CONSTANT (0);
|
GstClockTime itime = G_GINT64_CONSTANT (0);
|
||||||
|
|
||||||
GST_DEBUG (GST_CAT_CLOCK, "clock discont %" G_GUINT64_FORMAT
|
GST_CAT_DEBUG (GST_CAT_CLOCK, "clock discont %" G_GUINT64_FORMAT
|
||||||
" %" G_GUINT64_FORMAT " %d",
|
" %" G_GUINT64_FORMAT " %d",
|
||||||
time, clock->start_time, clock->accept_discont);
|
time, clock->start_time, clock->accept_discont);
|
||||||
|
|
||||||
|
@ -619,7 +620,7 @@ gst_clock_handle_discont (GstClock *clock, guint64 time)
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
GST_UNLOCK (clock);
|
GST_UNLOCK (clock);
|
||||||
GST_DEBUG (GST_CAT_CLOCK, "clock discont refused %" G_GUINT64_FORMAT
|
GST_CAT_DEBUG (GST_CAT_CLOCK, "clock discont refused %" G_GUINT64_FORMAT
|
||||||
" %" G_GUINT64_FORMAT,
|
" %" G_GUINT64_FORMAT,
|
||||||
time, clock->start_time);
|
time, clock->start_time);
|
||||||
return FALSE;
|
return FALSE;
|
||||||
|
@ -631,7 +632,7 @@ gst_clock_handle_discont (GstClock *clock, guint64 time)
|
||||||
g_list_foreach (clock->entries, (GFunc) gst_clock_reschedule_func, NULL);
|
g_list_foreach (clock->entries, (GFunc) gst_clock_reschedule_func, NULL);
|
||||||
GST_UNLOCK (clock);
|
GST_UNLOCK (clock);
|
||||||
|
|
||||||
GST_DEBUG (GST_CAT_CLOCK, "new time %" G_GUINT64_FORMAT,
|
GST_CAT_DEBUG (GST_CAT_CLOCK, "new time %" G_GUINT64_FORMAT,
|
||||||
gst_clock_get_time (clock));
|
gst_clock_get_time (clock));
|
||||||
|
|
||||||
g_mutex_lock (clock->active_mutex);
|
g_mutex_lock (clock->active_mutex);
|
||||||
|
|
|
@ -1,24 +0,0 @@
|
||||||
/* This header interprets the various GST_* macros that are typically *
|
|
||||||
* provided by the gstreamer-config or gstreamer.pc files. */
|
|
||||||
|
|
||||||
#ifndef __GST_CONFIG_H__
|
|
||||||
#define __GST_CONFIG_H__
|
|
||||||
|
|
||||||
|
|
||||||
/***** We include config.h in case someone perhaps used a gstreamer.m4 or
|
|
||||||
something else that provides funky overrides. BEWARE! *****/
|
|
||||||
|
|
||||||
#ifdef HAVE_CONFIG_H
|
|
||||||
#include "config.h"
|
|
||||||
#endif /* HAVE_CONFIG_H */
|
|
||||||
|
|
||||||
|
|
||||||
/***** Deal with XML stuff, we have to handle both loadsave and registry *****/
|
|
||||||
|
|
||||||
#if (! (defined(GST_DISABLE_LOADSAVE) && defined(GST_DISABLE_REGISTRY)) )
|
|
||||||
# include <libxml/parser.h>
|
|
||||||
#else
|
|
||||||
# define GST_DISABLE_LOADSAVE_REGISTRY
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#endif /* __GST_CONFIG_H__ */
|
|
73
gst/gstconfig.h.in
Normal file
73
gst/gstconfig.h.in
Normal file
|
@ -0,0 +1,73 @@
|
||||||
|
/* This header interprets the various GST_* macros that are typically *
|
||||||
|
* provided by the gstreamer-config or gstreamer.pc files. */
|
||||||
|
|
||||||
|
#ifndef __GST_CONFIG_H__
|
||||||
|
#define __GST_CONFIG_H__
|
||||||
|
|
||||||
|
/***** trick gtk-doc into believing these symbols are defined (yes, it's ugly) */
|
||||||
|
|
||||||
|
#if 0
|
||||||
|
#define GST_DISABLE_LOADSAVE_REGISTRY 1
|
||||||
|
#define GST_DISABLE_GST_DEBUG 1
|
||||||
|
#define GST_DISABLE_LOADSAVE 1
|
||||||
|
#define GST_DISABLE_TYPEFIND 1
|
||||||
|
#define GST_DISABLE_AUTOPLUG 1
|
||||||
|
#define GST_DISABLE_PARSE 1
|
||||||
|
#define GST_DISABLE_TRACE 1
|
||||||
|
#define GST_DISABLE_ALLOC_TRACE 1
|
||||||
|
#define GST_DISABLE_REGISTRY 1
|
||||||
|
#define GST_DISABLE_ENUMTYPES 1
|
||||||
|
#define GST_DISABLE_INDEX 1
|
||||||
|
#define GST_DISABLE_PLUGIN 1
|
||||||
|
#define GST_DISABLE_URI 1
|
||||||
|
#endif
|
||||||
|
|
||||||
|
|
||||||
|
/***** disabling of subsystems *****/
|
||||||
|
|
||||||
|
/* wether or not the debugging subsystem is enabled */
|
||||||
|
@GST_DISABLE_GST_DEBUG_DEFINE@
|
||||||
|
|
||||||
|
/* DOES NOT WORK */
|
||||||
|
@GST_DISABLE_LOADSAVE_DEFINE@
|
||||||
|
|
||||||
|
/* DOES NOT WORK */
|
||||||
|
@GST_DISABLE_TYPEFIND_DEFINE@
|
||||||
|
|
||||||
|
/* DOES NOT WORK */
|
||||||
|
@GST_DISABLE_AUTOPLUG_DEFINE@
|
||||||
|
|
||||||
|
/* DOES NOT WORK */
|
||||||
|
@GST_DISABLE_PARSE_DEFINE@
|
||||||
|
|
||||||
|
/* DOES NOT WORK */
|
||||||
|
@GST_DISABLE_TRACE_DEFINE@
|
||||||
|
|
||||||
|
/* DOES NOT WORK */
|
||||||
|
@GST_DISABLE_ALLOC_TRACE_DEFINE@
|
||||||
|
|
||||||
|
/* DOES NOT WORK */
|
||||||
|
@GST_DISABLE_REGISTRY_DEFINE@
|
||||||
|
|
||||||
|
/* DOES NOT WORK */
|
||||||
|
@GST_DISABLE_ENUMTYPES_DEFINE@
|
||||||
|
|
||||||
|
/* DOES NOT WORK */
|
||||||
|
@GST_DISABLE_INDEX_DEFINE@
|
||||||
|
|
||||||
|
/* DOES NOT WORK */
|
||||||
|
@GST_DISABLE_PLUGIN_DEFINE@
|
||||||
|
|
||||||
|
/* DOES NOT WORK */
|
||||||
|
@GST_DISABLE_URI_DEFINE@
|
||||||
|
|
||||||
|
|
||||||
|
/***** Deal with XML stuff, we have to handle both loadsave and registry *****/
|
||||||
|
|
||||||
|
#if (! (defined(GST_DISABLE_LOADSAVE) && defined(GST_DISABLE_REGISTRY)) )
|
||||||
|
# include <libxml/parser.h>
|
||||||
|
#else
|
||||||
|
# define GST_DISABLE_LOADSAVE_REGISTRY
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#endif /* __GST_CONFIG_H__ */
|
|
@ -24,7 +24,9 @@
|
||||||
#include <glib.h>
|
#include <glib.h>
|
||||||
|
|
||||||
#include "gst_private.h"
|
#include "gst_private.h"
|
||||||
|
|
||||||
#include "gstcpu.h"
|
#include "gstcpu.h"
|
||||||
|
#include "gstinfo.h"
|
||||||
|
|
||||||
static guint32 _gst_cpu_flags = 0;
|
static guint32 _gst_cpu_flags = 0;
|
||||||
|
|
||||||
|
@ -50,7 +52,7 @@ _gst_cpu_initialize (gboolean opt)
|
||||||
} else
|
} else
|
||||||
g_string_append (featurelist, "(DISABLED)");
|
g_string_append (featurelist, "(DISABLED)");
|
||||||
|
|
||||||
GST_INFO (GST_CAT_GST_INIT, "CPU features: (%08lx) %s", flags, featurelist->str);
|
GST_CAT_INFO (GST_CAT_GST_INIT, "CPU features: (%08lx) %s", flags, featurelist->str);
|
||||||
g_string_free (featurelist, TRUE);
|
g_string_free (featurelist, TRUE);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -20,15 +20,12 @@
|
||||||
* Boston, MA 02111-1307, USA.
|
* Boston, MA 02111-1307, USA.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
/* this file makes too much noise for most debugging sessions */
|
|
||||||
|
|
||||||
#define GST_DEBUG_FORCE_DISABLE
|
|
||||||
#include "gst_private.h"
|
#include "gst_private.h"
|
||||||
|
|
||||||
#include "gstatomic_impl.h"
|
#include "gstatomic_impl.h"
|
||||||
#include "gstdata.h"
|
#include "gstdata.h"
|
||||||
#include "gstdata_private.h"
|
#include "gstdata_private.h"
|
||||||
#include "gstlog.h"
|
#include "gstinfo.h"
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* gst_data_init:
|
* gst_data_init:
|
||||||
|
@ -234,7 +231,7 @@ gst_data_unref (GstData *data)
|
||||||
|
|
||||||
g_return_if_fail (data != NULL);
|
g_return_if_fail (data != NULL);
|
||||||
|
|
||||||
GST_INFO (GST_CAT_BUFFER, "unref data %p, count before unref is %d",
|
GST_CAT_LOG (GST_CAT_BUFFER, "unref data %p, count before unref is %d",
|
||||||
data, GST_DATA_REFCOUNT_VALUE (data));
|
data, GST_DATA_REFCOUNT_VALUE (data));
|
||||||
g_return_if_fail (GST_DATA_REFCOUNT_VALUE (data) > 0);
|
g_return_if_fail (GST_DATA_REFCOUNT_VALUE (data) > 0);
|
||||||
|
|
||||||
|
|
141
gst/gstelement.c
141
gst/gstelement.c
|
@ -20,7 +20,6 @@
|
||||||
* Boston, MA 02111-1307, USA.
|
* Boston, MA 02111-1307, USA.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
/* #define GST_DEBUG_ENABLED */
|
|
||||||
#include <glib.h>
|
#include <glib.h>
|
||||||
#include <stdarg.h>
|
#include <stdarg.h>
|
||||||
#include <gobject/gvaluecollector.h>
|
#include <gobject/gvaluecollector.h>
|
||||||
|
@ -31,7 +30,7 @@
|
||||||
#include "gstscheduler.h"
|
#include "gstscheduler.h"
|
||||||
#include "gstevent.h"
|
#include "gstevent.h"
|
||||||
#include "gstutils.h"
|
#include "gstutils.h"
|
||||||
#include "gstlog.h"
|
#include "gstinfo.h"
|
||||||
|
|
||||||
/* Element signals and args */
|
/* Element signals and args */
|
||||||
enum {
|
enum {
|
||||||
|
@ -239,7 +238,7 @@ element_get_property (GstElement *element, const GParamSpec *pspec, GValue *valu
|
||||||
static void
|
static void
|
||||||
gst_element_threadsafe_properties_pre_run (GstElement *element)
|
gst_element_threadsafe_properties_pre_run (GstElement *element)
|
||||||
{
|
{
|
||||||
GST_DEBUG (GST_CAT_THREAD, "locking element %s", GST_OBJECT_NAME (element));
|
GST_CAT_DEBUG (GST_CAT_THREAD, "locking element %s", GST_OBJECT_NAME (element));
|
||||||
g_mutex_lock (element->property_mutex);
|
g_mutex_lock (element->property_mutex);
|
||||||
gst_element_set_pending_properties (element);
|
gst_element_set_pending_properties (element);
|
||||||
}
|
}
|
||||||
|
@ -247,7 +246,7 @@ gst_element_threadsafe_properties_pre_run (GstElement *element)
|
||||||
static void
|
static void
|
||||||
gst_element_threadsafe_properties_post_run (GstElement *element)
|
gst_element_threadsafe_properties_post_run (GstElement *element)
|
||||||
{
|
{
|
||||||
GST_DEBUG (GST_CAT_THREAD, "unlocking element %s", GST_OBJECT_NAME (element));
|
GST_CAT_DEBUG (GST_CAT_THREAD, "unlocking element %s", GST_OBJECT_NAME (element));
|
||||||
g_mutex_unlock (element->property_mutex);
|
g_mutex_unlock (element->property_mutex);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -375,7 +374,7 @@ gst_element_set_valist (GstElement *element, const gchar *first_property_name, v
|
||||||
|
|
||||||
object = (GObject *) element;
|
object = (GObject *) element;
|
||||||
|
|
||||||
GST_DEBUG (GST_CAT_PROPERTIES,
|
GST_CAT_DEBUG (GST_CAT_PROPERTIES,
|
||||||
"setting valist of properties starting with %s on element %s",
|
"setting valist of properties starting with %s on element %s",
|
||||||
first_property_name, gst_element_get_name (element));
|
first_property_name, gst_element_get_name (element));
|
||||||
|
|
||||||
|
@ -532,7 +531,7 @@ gst_element_set_property (GstElement *element, const gchar *property_name,
|
||||||
|
|
||||||
object = (GObject*) element;
|
object = (GObject*) element;
|
||||||
|
|
||||||
GST_DEBUG (GST_CAT_PROPERTIES, "setting property %s on element %s",
|
GST_CAT_DEBUG (GST_CAT_PROPERTIES, "setting property %s on element %s",
|
||||||
property_name, gst_element_get_name (element));
|
property_name, gst_element_get_name (element));
|
||||||
if (!GST_FLAG_IS_SET (element, GST_ELEMENT_USE_THREADSAFE_PROPERTIES)) {
|
if (!GST_FLAG_IS_SET (element, GST_ELEMENT_USE_THREADSAFE_PROPERTIES)) {
|
||||||
g_object_set_property (object, property_name, value);
|
g_object_set_property (object, property_name, value);
|
||||||
|
@ -757,11 +756,11 @@ gst_element_clock_wait (GstElement *element, GstClockID id, GstClockTimeDiff *ji
|
||||||
g_return_val_if_fail (GST_IS_ELEMENT (element), GST_CLOCK_ERROR);
|
g_return_val_if_fail (GST_IS_ELEMENT (element), GST_CLOCK_ERROR);
|
||||||
|
|
||||||
if (GST_ELEMENT_SCHED (element)) {
|
if (GST_ELEMENT_SCHED (element)) {
|
||||||
GST_DEBUG (GST_CAT_CLOCK, "waiting on scheduler clock");
|
GST_CAT_DEBUG (GST_CAT_CLOCK, "waiting on scheduler clock");
|
||||||
res = gst_scheduler_clock_wait (GST_ELEMENT_SCHED (element), element, id, jitter);
|
res = gst_scheduler_clock_wait (GST_ELEMENT_SCHED (element), element, id, jitter);
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
GST_DEBUG (GST_CAT_CLOCK, "no scheduler, returning GST_CLOCK_TIMEOUT");
|
GST_CAT_DEBUG (GST_CAT_CLOCK, "no scheduler, returning GST_CLOCK_TIMEOUT");
|
||||||
res = GST_CLOCK_TIMEOUT;
|
res = GST_CLOCK_TIMEOUT;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -877,7 +876,7 @@ gst_element_add_pad (GstElement *element, GstPad *pad)
|
||||||
g_return_if_fail (gst_object_check_uniqueness (element->pads, GST_PAD_NAME(pad)) == TRUE);
|
g_return_if_fail (gst_object_check_uniqueness (element->pads, GST_PAD_NAME(pad)) == TRUE);
|
||||||
|
|
||||||
/* set the pad's parent */
|
/* set the pad's parent */
|
||||||
GST_DEBUG (GST_CAT_ELEMENT_PADS,"setting parent of pad '%s' to '%s'",
|
GST_CAT_DEBUG (GST_CAT_ELEMENT_PADS,"setting parent of pad '%s' to '%s'",
|
||||||
GST_PAD_NAME (pad), GST_STR_NULL (GST_ELEMENT_NAME (element)));
|
GST_PAD_NAME (pad), GST_STR_NULL (GST_ELEMENT_NAME (element)));
|
||||||
gst_object_set_parent (GST_OBJECT (pad), GST_OBJECT (element));
|
gst_object_set_parent (GST_OBJECT (pad), GST_OBJECT (element));
|
||||||
|
|
||||||
|
@ -958,20 +957,20 @@ gst_element_add_ghost_pad (GstElement *element, GstPad *pad, const gchar *name)
|
||||||
/* then check to see if there's already a pad by that name here */
|
/* then check to see if there's already a pad by that name here */
|
||||||
g_return_val_if_fail (gst_object_check_uniqueness (element->pads, name) == TRUE, NULL);
|
g_return_val_if_fail (gst_object_check_uniqueness (element->pads, name) == TRUE, NULL);
|
||||||
|
|
||||||
GST_DEBUG (GST_CAT_ELEMENT_PADS,
|
GST_CAT_DEBUG (GST_CAT_ELEMENT_PADS,
|
||||||
"creating new ghost pad called %s, from pad %s:%s",
|
"creating new ghost pad called %s, from pad %s:%s",
|
||||||
name, GST_DEBUG_PAD_NAME(pad));
|
name, GST_DEBUG_PAD_NAME(pad));
|
||||||
ghostpad = gst_ghost_pad_new (name, pad);
|
ghostpad = gst_ghost_pad_new (name, pad);
|
||||||
|
|
||||||
/* add it to the list */
|
/* add it to the list */
|
||||||
GST_DEBUG(GST_CAT_ELEMENT_PADS,"adding ghost pad %s to element %s",
|
GST_CAT_DEBUG (GST_CAT_ELEMENT_PADS,"adding ghost pad %s to element %s",
|
||||||
name, GST_ELEMENT_NAME (element));
|
name, GST_ELEMENT_NAME (element));
|
||||||
element->pads = g_list_append (element->pads, ghostpad);
|
element->pads = g_list_append (element->pads, ghostpad);
|
||||||
element->numpads++;
|
element->numpads++;
|
||||||
/* set the parent of the ghostpad */
|
/* set the parent of the ghostpad */
|
||||||
gst_object_set_parent (GST_OBJECT (ghostpad), GST_OBJECT (element));
|
gst_object_set_parent (GST_OBJECT (ghostpad), GST_OBJECT (element));
|
||||||
|
|
||||||
GST_DEBUG(GST_CAT_ELEMENT_PADS,"added ghostpad %s:%s",GST_DEBUG_PAD_NAME(ghostpad));
|
GST_CAT_DEBUG (GST_CAT_ELEMENT_PADS,"added ghostpad %s:%s",GST_DEBUG_PAD_NAME(ghostpad));
|
||||||
|
|
||||||
/* emit the NEW_GHOST_PAD signal */
|
/* emit the NEW_GHOST_PAD signal */
|
||||||
g_signal_emit (G_OBJECT (element), gst_element_signals[NEW_PAD], 0, ghostpad);
|
g_signal_emit (G_OBJECT (element), gst_element_signals[NEW_PAD], 0, ghostpad);
|
||||||
|
@ -1054,13 +1053,13 @@ gst_element_get_static_pad (GstElement *element, const gchar *name)
|
||||||
|
|
||||||
pad = GST_PAD(walk->data);
|
pad = GST_PAD(walk->data);
|
||||||
if (strcmp (GST_PAD_NAME(pad), name) == 0) {
|
if (strcmp (GST_PAD_NAME(pad), name) == 0) {
|
||||||
GST_INFO (GST_CAT_ELEMENT_PADS, "found pad %s:%s", GST_DEBUG_PAD_NAME (pad));
|
GST_CAT_INFO (GST_CAT_ELEMENT_PADS, "found pad %s:%s", GST_DEBUG_PAD_NAME (pad));
|
||||||
return pad;
|
return pad;
|
||||||
}
|
}
|
||||||
walk = g_list_next (walk);
|
walk = g_list_next (walk);
|
||||||
}
|
}
|
||||||
|
|
||||||
GST_INFO (GST_CAT_ELEMENT_PADS, "no such pad '%s' in element \"%s\"", name, GST_OBJECT_NAME (element));
|
GST_CAT_INFO (GST_CAT_ELEMENT_PADS, "no such pad '%s' in element \"%s\"", name, GST_OBJECT_NAME (element));
|
||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1102,7 +1101,7 @@ gst_element_get_request_pad (GstElement *element, const gchar *name)
|
||||||
if (templ->presence == GST_PAD_REQUEST) {
|
if (templ->presence == GST_PAD_REQUEST) {
|
||||||
/* we know that %s and %d are the only possibilities because of sanity
|
/* we know that %s and %d are the only possibilities because of sanity
|
||||||
checks in gst_pad_template_new */
|
checks in gst_pad_template_new */
|
||||||
GST_DEBUG (GST_CAT_PADS, "comparing %s to %s", name, templ->name_template);
|
GST_CAT_DEBUG (GST_CAT_PADS, "comparing %s to %s", name, templ->name_template);
|
||||||
if ((str = strchr (templ->name_template, '%')) &&
|
if ((str = strchr (templ->name_template, '%')) &&
|
||||||
strncmp (templ->name_template, name, str - templ->name_template) == 0 &&
|
strncmp (templ->name_template, name, str - templ->name_template) == 0 &&
|
||||||
strlen (name) > str - templ->name_template) {
|
strlen (name) > str - templ->name_template) {
|
||||||
|
@ -1246,7 +1245,7 @@ gst_element_get_compatible_pad_template (GstElement *element,
|
||||||
GstPadTemplate *newtempl = NULL;
|
GstPadTemplate *newtempl = NULL;
|
||||||
GList *padlist;
|
GList *padlist;
|
||||||
|
|
||||||
GST_DEBUG (GST_CAT_ELEMENT_PADS, "gst_element_get_compatible_pad_template()");
|
GST_CAT_DEBUG (GST_CAT_ELEMENT_PADS, "gst_element_get_compatible_pad_template()");
|
||||||
|
|
||||||
g_return_val_if_fail (element != NULL, NULL);
|
g_return_val_if_fail (element != NULL, NULL);
|
||||||
g_return_val_if_fail (GST_IS_ELEMENT (element), NULL);
|
g_return_val_if_fail (GST_IS_ELEMENT (element), NULL);
|
||||||
|
@ -1263,19 +1262,19 @@ gst_element_get_compatible_pad_template (GstElement *element,
|
||||||
* Check direction (must be opposite)
|
* Check direction (must be opposite)
|
||||||
* Check caps
|
* Check caps
|
||||||
*/
|
*/
|
||||||
GST_DEBUG (GST_CAT_CAPS, "checking direction and caps");
|
GST_CAT_DEBUG (GST_CAT_CAPS, "checking direction and caps");
|
||||||
if (padtempl->direction == GST_PAD_SRC &&
|
if (padtempl->direction == GST_PAD_SRC &&
|
||||||
compattempl->direction == GST_PAD_SINK) {
|
compattempl->direction == GST_PAD_SINK) {
|
||||||
GST_DEBUG (GST_CAT_CAPS, "compatible direction: found src pad template");
|
GST_CAT_DEBUG (GST_CAT_CAPS, "compatible direction: found src pad template");
|
||||||
comp = gst_caps_is_always_compatible (GST_PAD_TEMPLATE_CAPS (padtempl),
|
comp = gst_caps_is_always_compatible (GST_PAD_TEMPLATE_CAPS (padtempl),
|
||||||
GST_PAD_TEMPLATE_CAPS (compattempl));
|
GST_PAD_TEMPLATE_CAPS (compattempl));
|
||||||
GST_DEBUG(GST_CAT_CAPS, "caps are %scompatible", (comp ? "" : "not "));
|
GST_CAT_DEBUG (GST_CAT_CAPS, "caps are %scompatible", (comp ? "" : "not "));
|
||||||
} else if (padtempl->direction == GST_PAD_SINK &&
|
} else if (padtempl->direction == GST_PAD_SINK &&
|
||||||
compattempl->direction == GST_PAD_SRC) {
|
compattempl->direction == GST_PAD_SRC) {
|
||||||
GST_DEBUG (GST_CAT_CAPS, "compatible direction: found sink pad template");
|
GST_CAT_DEBUG (GST_CAT_CAPS, "compatible direction: found sink pad template");
|
||||||
comp = gst_caps_is_always_compatible (GST_PAD_TEMPLATE_CAPS (compattempl),
|
comp = gst_caps_is_always_compatible (GST_PAD_TEMPLATE_CAPS (compattempl),
|
||||||
GST_PAD_TEMPLATE_CAPS (padtempl));
|
GST_PAD_TEMPLATE_CAPS (padtempl));
|
||||||
GST_DEBUG (GST_CAT_CAPS, "caps are %scompatible", (comp ? "" : "not "));
|
GST_CAT_DEBUG (GST_CAT_CAPS, "caps are %scompatible", (comp ? "" : "not "));
|
||||||
}
|
}
|
||||||
|
|
||||||
if (comp) {
|
if (comp) {
|
||||||
|
@ -1435,7 +1434,7 @@ gst_element_link_pads_filtered (GstElement *src, const gchar *srcpadname,
|
||||||
g_return_val_if_fail (GST_IS_ELEMENT (src), FALSE);
|
g_return_val_if_fail (GST_IS_ELEMENT (src), FALSE);
|
||||||
g_return_val_if_fail (GST_IS_ELEMENT (dest), FALSE);
|
g_return_val_if_fail (GST_IS_ELEMENT (dest), FALSE);
|
||||||
|
|
||||||
GST_INFO (GST_CAT_ELEMENT_PADS, "trying to link element %s:%s to element %s:%s",
|
GST_CAT_INFO (GST_CAT_ELEMENT_PADS, "trying to link element %s:%s to element %s:%s",
|
||||||
GST_ELEMENT_NAME (src), srcpadname ? srcpadname : "(any)",
|
GST_ELEMENT_NAME (src), srcpadname ? srcpadname : "(any)",
|
||||||
GST_ELEMENT_NAME (dest), destpadname ? destpadname : "(any)");
|
GST_ELEMENT_NAME (dest), destpadname ? destpadname : "(any)");
|
||||||
|
|
||||||
|
@ -1443,15 +1442,15 @@ gst_element_link_pads_filtered (GstElement *src, const gchar *srcpadname,
|
||||||
if (srcpadname) {
|
if (srcpadname) {
|
||||||
srcpad = gst_element_get_pad (src, srcpadname);
|
srcpad = gst_element_get_pad (src, srcpadname);
|
||||||
if (!srcpad) {
|
if (!srcpad) {
|
||||||
GST_DEBUG (GST_CAT_ELEMENT_PADS, "no pad %s:%s", GST_ELEMENT_NAME (src), srcpadname);
|
GST_CAT_DEBUG (GST_CAT_ELEMENT_PADS, "no pad %s:%s", GST_ELEMENT_NAME (src), srcpadname);
|
||||||
return FALSE;
|
return FALSE;
|
||||||
} else {
|
} else {
|
||||||
if (!(GST_RPAD_DIRECTION (srcpad) == GST_PAD_SRC)) {
|
if (!(GST_RPAD_DIRECTION (srcpad) == GST_PAD_SRC)) {
|
||||||
GST_DEBUG (GST_CAT_ELEMENT_PADS, "pad %s:%s is no src pad", GST_DEBUG_PAD_NAME (srcpad));
|
GST_CAT_DEBUG (GST_CAT_ELEMENT_PADS, "pad %s:%s is no src pad", GST_DEBUG_PAD_NAME (srcpad));
|
||||||
return FALSE;
|
return FALSE;
|
||||||
}
|
}
|
||||||
if (GST_PAD_PEER (srcpad) != NULL) {
|
if (GST_PAD_PEER (srcpad) != NULL) {
|
||||||
GST_DEBUG (GST_CAT_ELEMENT_PADS, "pad %s:%s is already linked", GST_DEBUG_PAD_NAME (srcpad));
|
GST_CAT_DEBUG (GST_CAT_ELEMENT_PADS, "pad %s:%s is already linked", GST_DEBUG_PAD_NAME (srcpad));
|
||||||
return FALSE;
|
return FALSE;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -1463,15 +1462,15 @@ gst_element_link_pads_filtered (GstElement *src, const gchar *srcpadname,
|
||||||
if (destpadname) {
|
if (destpadname) {
|
||||||
destpad = gst_element_get_pad (dest, destpadname);
|
destpad = gst_element_get_pad (dest, destpadname);
|
||||||
if (!destpad) {
|
if (!destpad) {
|
||||||
GST_DEBUG (GST_CAT_ELEMENT_PADS, "no pad %s:%s", GST_ELEMENT_NAME (dest), destpadname);
|
GST_CAT_DEBUG (GST_CAT_ELEMENT_PADS, "no pad %s:%s", GST_ELEMENT_NAME (dest), destpadname);
|
||||||
return FALSE;
|
return FALSE;
|
||||||
} else {
|
} else {
|
||||||
if (!(GST_RPAD_DIRECTION (destpad) == GST_PAD_SINK)) {
|
if (!(GST_RPAD_DIRECTION (destpad) == GST_PAD_SINK)) {
|
||||||
GST_DEBUG (GST_CAT_ELEMENT_PADS, "pad %s:%s is no sink pad", GST_DEBUG_PAD_NAME (destpad));
|
GST_CAT_DEBUG (GST_CAT_ELEMENT_PADS, "pad %s:%s is no sink pad", GST_DEBUG_PAD_NAME (destpad));
|
||||||
return FALSE;
|
return FALSE;
|
||||||
}
|
}
|
||||||
if (GST_PAD_PEER (destpad) != NULL) {
|
if (GST_PAD_PEER (destpad) != NULL) {
|
||||||
GST_DEBUG (GST_CAT_ELEMENT_PADS, "pad %s:%s is already linked", GST_DEBUG_PAD_NAME (destpad));
|
GST_CAT_DEBUG (GST_CAT_ELEMENT_PADS, "pad %s:%s is already linked", GST_DEBUG_PAD_NAME (destpad));
|
||||||
return FALSE;
|
return FALSE;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -1488,16 +1487,16 @@ gst_element_link_pads_filtered (GstElement *src, const gchar *srcpadname,
|
||||||
if (srcpad) {
|
if (srcpad) {
|
||||||
/* loop through the allowed pads in the source, trying to find a
|
/* loop through the allowed pads in the source, trying to find a
|
||||||
* compatible destination pad */
|
* compatible destination pad */
|
||||||
GST_DEBUG (GST_CAT_ELEMENT_PADS, "looping through allowed src and dest pads");
|
GST_CAT_DEBUG (GST_CAT_ELEMENT_PADS, "looping through allowed src and dest pads");
|
||||||
do {
|
do {
|
||||||
GST_DEBUG (GST_CAT_ELEMENT_PADS, "trying src pad %s:%s",
|
GST_CAT_DEBUG (GST_CAT_ELEMENT_PADS, "trying src pad %s:%s",
|
||||||
GST_DEBUG_PAD_NAME (srcpad));
|
GST_DEBUG_PAD_NAME (srcpad));
|
||||||
if ((GST_RPAD_DIRECTION (srcpad) == GST_PAD_SRC) &&
|
if ((GST_RPAD_DIRECTION (srcpad) == GST_PAD_SRC) &&
|
||||||
(GST_PAD_PEER (srcpad) == NULL)) {
|
(GST_PAD_PEER (srcpad) == NULL)) {
|
||||||
GstPad *temp = gst_element_get_compatible_pad_filtered (dest, srcpad,
|
GstPad *temp = gst_element_get_compatible_pad_filtered (dest, srcpad,
|
||||||
filtercaps);
|
filtercaps);
|
||||||
if (temp && gst_pad_link_filtered (srcpad, temp, filtercaps)) {
|
if (temp && gst_pad_link_filtered (srcpad, temp, filtercaps)) {
|
||||||
GST_DEBUG (GST_CAT_ELEMENT_PADS, "linked pad %s:%s to pad %s:%s",
|
GST_CAT_DEBUG (GST_CAT_ELEMENT_PADS, "linked pad %s:%s to pad %s:%s",
|
||||||
GST_DEBUG_PAD_NAME (srcpad), GST_DEBUG_PAD_NAME (temp));
|
GST_DEBUG_PAD_NAME (srcpad), GST_DEBUG_PAD_NAME (temp));
|
||||||
return TRUE;
|
return TRUE;
|
||||||
}
|
}
|
||||||
|
@ -1511,21 +1510,21 @@ gst_element_link_pads_filtered (GstElement *src, const gchar *srcpadname,
|
||||||
} while (srcpads);
|
} while (srcpads);
|
||||||
}
|
}
|
||||||
if (srcpadname) {
|
if (srcpadname) {
|
||||||
GST_DEBUG (GST_CAT_ELEMENT_PADS, "no link possible from %s:%s to %s",
|
GST_CAT_DEBUG (GST_CAT_ELEMENT_PADS, "no link possible from %s:%s to %s",
|
||||||
GST_DEBUG_PAD_NAME (srcpad), GST_ELEMENT_NAME (dest));
|
GST_DEBUG_PAD_NAME (srcpad), GST_ELEMENT_NAME (dest));
|
||||||
return FALSE;
|
return FALSE;
|
||||||
}
|
}
|
||||||
if (destpad) {
|
if (destpad) {
|
||||||
/* loop through the existing pads in the destination */
|
/* loop through the existing pads in the destination */
|
||||||
do {
|
do {
|
||||||
GST_DEBUG (GST_CAT_ELEMENT_PADS, "trying dest pad %s:%s",
|
GST_CAT_DEBUG (GST_CAT_ELEMENT_PADS, "trying dest pad %s:%s",
|
||||||
GST_DEBUG_PAD_NAME (destpad));
|
GST_DEBUG_PAD_NAME (destpad));
|
||||||
if ((GST_RPAD_DIRECTION (destpad) == GST_PAD_SINK) &&
|
if ((GST_RPAD_DIRECTION (destpad) == GST_PAD_SINK) &&
|
||||||
(GST_PAD_PEER (destpad) == NULL)) {
|
(GST_PAD_PEER (destpad) == NULL)) {
|
||||||
GstPad *temp = gst_element_get_compatible_pad_filtered (src, destpad,
|
GstPad *temp = gst_element_get_compatible_pad_filtered (src, destpad,
|
||||||
filtercaps);
|
filtercaps);
|
||||||
if (temp && gst_pad_link_filtered (temp, destpad, filtercaps)) {
|
if (temp && gst_pad_link_filtered (temp, destpad, filtercaps)) {
|
||||||
GST_DEBUG (GST_CAT_ELEMENT_PADS, "linked pad %s:%s to pad %s:%s",
|
GST_CAT_DEBUG (GST_CAT_ELEMENT_PADS, "linked pad %s:%s to pad %s:%s",
|
||||||
GST_DEBUG_PAD_NAME (temp), GST_DEBUG_PAD_NAME (destpad));
|
GST_DEBUG_PAD_NAME (temp), GST_DEBUG_PAD_NAME (destpad));
|
||||||
return TRUE;
|
return TRUE;
|
||||||
}
|
}
|
||||||
|
@ -1538,12 +1537,12 @@ gst_element_link_pads_filtered (GstElement *src, const gchar *srcpadname,
|
||||||
} while (destpads);
|
} while (destpads);
|
||||||
}
|
}
|
||||||
if (destpadname) {
|
if (destpadname) {
|
||||||
GST_DEBUG (GST_CAT_ELEMENT_PADS, "no link possible from %s to %s:%s",
|
GST_CAT_DEBUG (GST_CAT_ELEMENT_PADS, "no link possible from %s to %s:%s",
|
||||||
GST_ELEMENT_NAME (src), GST_DEBUG_PAD_NAME (destpad));
|
GST_ELEMENT_NAME (src), GST_DEBUG_PAD_NAME (destpad));
|
||||||
return FALSE;
|
return FALSE;
|
||||||
}
|
}
|
||||||
|
|
||||||
GST_DEBUG (GST_CAT_ELEMENT_PADS,
|
GST_CAT_DEBUG (GST_CAT_ELEMENT_PADS,
|
||||||
"we might have request pads on both sides, checking...");
|
"we might have request pads on both sides, checking...");
|
||||||
srctempls = gst_element_get_pad_template_list (src);
|
srctempls = gst_element_get_pad_template_list (src);
|
||||||
desttempls = gst_element_get_pad_template_list (dest);
|
desttempls = gst_element_get_pad_template_list (dest);
|
||||||
|
@ -1563,7 +1562,7 @@ gst_element_link_pads_filtered (GstElement *src, const gchar *srcpadname,
|
||||||
destpad = gst_element_get_request_pad (dest,
|
destpad = gst_element_get_request_pad (dest,
|
||||||
desttempl->name_template);
|
desttempl->name_template);
|
||||||
if (gst_pad_link_filtered (srcpad, destpad, filtercaps)) {
|
if (gst_pad_link_filtered (srcpad, destpad, filtercaps)) {
|
||||||
GST_DEBUG (GST_CAT_ELEMENT_PADS,
|
GST_CAT_DEBUG (GST_CAT_ELEMENT_PADS,
|
||||||
"linked pad %s:%s to pad %s:%s",
|
"linked pad %s:%s to pad %s:%s",
|
||||||
GST_DEBUG_PAD_NAME (srcpad),
|
GST_DEBUG_PAD_NAME (srcpad),
|
||||||
GST_DEBUG_PAD_NAME (destpad));
|
GST_DEBUG_PAD_NAME (destpad));
|
||||||
|
@ -1578,7 +1577,7 @@ gst_element_link_pads_filtered (GstElement *src, const gchar *srcpadname,
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
GST_DEBUG (GST_CAT_ELEMENT_PADS, "no link possible from %s to %s",
|
GST_CAT_DEBUG (GST_CAT_ELEMENT_PADS, "no link possible from %s to %s",
|
||||||
GST_ELEMENT_NAME (src), GST_ELEMENT_NAME (dest));
|
GST_ELEMENT_NAME (src), GST_ELEMENT_NAME (dest));
|
||||||
return FALSE;
|
return FALSE;
|
||||||
}
|
}
|
||||||
|
@ -1704,12 +1703,12 @@ gst_element_unlink_pads (GstElement *src, const gchar *srcpadname,
|
||||||
/* obtain the pads requested */
|
/* obtain the pads requested */
|
||||||
srcpad = gst_element_get_pad (src, srcpadname);
|
srcpad = gst_element_get_pad (src, srcpadname);
|
||||||
if (srcpad == NULL) {
|
if (srcpad == NULL) {
|
||||||
GST_ERROR(src,"source element has no pad \"%s\"",srcpadname);
|
GST_WARNING_OBJECT (src, "source element has no pad \"%s\"", srcpadname);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
destpad = gst_element_get_pad (dest, destpadname);
|
destpad = gst_element_get_pad (dest, destpadname);
|
||||||
if (srcpad == NULL) {
|
if (srcpad == NULL) {
|
||||||
GST_ERROR(dest,"destination element has no pad \"%s\"",destpadname);
|
GST_WARNING_OBJECT (dest, "destination element has no pad \"%s\"", destpadname);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1762,7 +1761,7 @@ gst_element_unlink (GstElement *src, GstElement *dest)
|
||||||
g_return_if_fail (GST_IS_ELEMENT (src));
|
g_return_if_fail (GST_IS_ELEMENT (src));
|
||||||
g_return_if_fail (GST_IS_ELEMENT (dest));
|
g_return_if_fail (GST_IS_ELEMENT (dest));
|
||||||
|
|
||||||
GST_DEBUG (GST_CAT_ELEMENT_PADS, "unlinking \"%s\" and \"%s\"",
|
GST_CAT_DEBUG (GST_CAT_ELEMENT_PADS, "unlinking \"%s\" and \"%s\"",
|
||||||
GST_ELEMENT_NAME (src), GST_ELEMENT_NAME (dest));
|
GST_ELEMENT_NAME (src), GST_ELEMENT_NAME (dest));
|
||||||
|
|
||||||
srcpads = gst_element_get_pad_list (src);
|
srcpads = gst_element_get_pad_list (src);
|
||||||
|
@ -1793,7 +1792,7 @@ gst_element_error_func (GstElement* element, GstElement *source,
|
||||||
{
|
{
|
||||||
/* tell the parent */
|
/* tell the parent */
|
||||||
if (GST_OBJECT_PARENT (element)) {
|
if (GST_OBJECT_PARENT (element)) {
|
||||||
GST_DEBUG (GST_CAT_EVENT, "forwarding error \"%s\" from %s to %s",
|
GST_CAT_DEBUG (GST_CAT_EVENT, "forwarding error \"%s\" from %s to %s",
|
||||||
errormsg, GST_ELEMENT_NAME (element),
|
errormsg, GST_ELEMENT_NAME (element),
|
||||||
GST_OBJECT_NAME (GST_OBJECT_PARENT (element)));
|
GST_OBJECT_NAME (GST_OBJECT_PARENT (element)));
|
||||||
|
|
||||||
|
@ -1808,11 +1807,11 @@ static GstPad*
|
||||||
gst_element_get_random_pad (GstElement *element, GstPadDirection dir)
|
gst_element_get_random_pad (GstElement *element, GstPadDirection dir)
|
||||||
{
|
{
|
||||||
GList *pads = element->pads;
|
GList *pads = element->pads;
|
||||||
GST_DEBUG (GST_CAT_ELEMENT_PADS, "getting a random pad");
|
GST_CAT_DEBUG (GST_CAT_ELEMENT_PADS, "getting a random pad");
|
||||||
while (pads) {
|
while (pads) {
|
||||||
GstPad *pad = GST_PAD_CAST (pads->data);
|
GstPad *pad = GST_PAD_CAST (pads->data);
|
||||||
|
|
||||||
GST_DEBUG (GST_CAT_ELEMENT_PADS, "checking pad %s:%s",
|
GST_CAT_DEBUG (GST_CAT_ELEMENT_PADS, "checking pad %s:%s",
|
||||||
GST_DEBUG_PAD_NAME (pad));
|
GST_DEBUG_PAD_NAME (pad));
|
||||||
|
|
||||||
if (GST_PAD_DIRECTION (pad) == dir) {
|
if (GST_PAD_DIRECTION (pad) == dir) {
|
||||||
|
@ -1820,12 +1819,12 @@ gst_element_get_random_pad (GstElement *element, GstPadDirection dir)
|
||||||
return pad;
|
return pad;
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
GST_DEBUG (GST_CAT_ELEMENT_PADS, "pad %s:%s is not linked",
|
GST_CAT_DEBUG (GST_CAT_ELEMENT_PADS, "pad %s:%s is not linked",
|
||||||
GST_DEBUG_PAD_NAME (pad));
|
GST_DEBUG_PAD_NAME (pad));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
GST_DEBUG (GST_CAT_ELEMENT_PADS, "pad %s:%s is in wrong direction",
|
GST_CAT_DEBUG (GST_CAT_ELEMENT_PADS, "pad %s:%s is in wrong direction",
|
||||||
GST_DEBUG_PAD_NAME (pad));
|
GST_DEBUG_PAD_NAME (pad));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1891,12 +1890,12 @@ gst_element_send_event (GstElement *element, GstEvent *event)
|
||||||
else {
|
else {
|
||||||
GstPad *pad = gst_element_get_random_pad (element, GST_PAD_SINK);
|
GstPad *pad = gst_element_get_random_pad (element, GST_PAD_SINK);
|
||||||
if (pad) {
|
if (pad) {
|
||||||
GST_DEBUG (GST_CAT_ELEMENT_PADS, "sending event to random pad %s:%s",
|
GST_CAT_DEBUG (GST_CAT_ELEMENT_PADS, "sending event to random pad %s:%s",
|
||||||
GST_DEBUG_PAD_NAME (pad));
|
GST_DEBUG_PAD_NAME (pad));
|
||||||
return gst_pad_send_event (GST_PAD_PEER (pad), event);
|
return gst_pad_send_event (GST_PAD_PEER (pad), event);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
GST_DEBUG (GST_CAT_ELEMENT_PADS, "can't send event on element %s",
|
GST_CAT_DEBUG (GST_CAT_ELEMENT_PADS, "can't send event on element %s",
|
||||||
GST_ELEMENT_NAME (element));
|
GST_ELEMENT_NAME (element));
|
||||||
return FALSE;
|
return FALSE;
|
||||||
}
|
}
|
||||||
|
@ -2073,11 +2072,11 @@ gst_element_error (GstElement *element, const gchar *error, ...)
|
||||||
va_start (var_args, error);
|
va_start (var_args, error);
|
||||||
string = g_strdup_vprintf (error, var_args);
|
string = g_strdup_vprintf (error, var_args);
|
||||||
va_end (var_args);
|
va_end (var_args);
|
||||||
GST_INFO (GST_CAT_EVENT, "ERROR in %s: %s", GST_ELEMENT_NAME (element), string);
|
GST_CAT_INFO (GST_CAT_EVENT, "ERROR in %s: %s", GST_ELEMENT_NAME (element), string);
|
||||||
|
|
||||||
/* if the element was already in error, stop now */
|
/* if the element was already in error, stop now */
|
||||||
if (GST_FLAG_IS_SET (element, GST_ELEMENT_ERROR)) {
|
if (GST_FLAG_IS_SET (element, GST_ELEMENT_ERROR)) {
|
||||||
GST_INFO (GST_CAT_EVENT, "recursive ERROR detected in %s", GST_ELEMENT_NAME (element));
|
GST_CAT_INFO (GST_CAT_EVENT, "recursive ERROR detected in %s", GST_ELEMENT_NAME (element));
|
||||||
g_free (string);
|
g_free (string);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
@ -2149,11 +2148,11 @@ gst_element_set_locked_state (GstElement *element, gboolean locked_state)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
if (locked_state) {
|
if (locked_state) {
|
||||||
GST_DEBUG (GST_CAT_STATES, "locking state of element %s",
|
GST_CAT_DEBUG (GST_CAT_STATES, "locking state of element %s",
|
||||||
GST_ELEMENT_NAME (element));
|
GST_ELEMENT_NAME (element));
|
||||||
GST_FLAG_SET (element, GST_ELEMENT_LOCKED_STATE);
|
GST_FLAG_SET (element, GST_ELEMENT_LOCKED_STATE);
|
||||||
} else {
|
} else {
|
||||||
GST_DEBUG (GST_CAT_STATES, "unlocking state of element %s",
|
GST_CAT_DEBUG (GST_CAT_STATES, "unlocking state of element %s",
|
||||||
GST_ELEMENT_NAME (element));
|
GST_ELEMENT_NAME (element));
|
||||||
GST_FLAG_UNSET (element, GST_ELEMENT_LOCKED_STATE);
|
GST_FLAG_UNSET (element, GST_ELEMENT_LOCKED_STATE);
|
||||||
}
|
}
|
||||||
|
@ -2176,7 +2175,7 @@ gst_element_sync_state_with_parent (GstElement *element)
|
||||||
parent = GST_ELEMENT (GST_ELEMENT_PARENT(element));
|
parent = GST_ELEMENT (GST_ELEMENT_PARENT(element));
|
||||||
g_return_val_if_fail (GST_IS_BIN (parent), FALSE);
|
g_return_val_if_fail (GST_IS_BIN (parent), FALSE);
|
||||||
|
|
||||||
GST_DEBUG (GST_CAT_STATES, "syncing state of element %s (%s) to %s (%s)",
|
GST_CAT_DEBUG (GST_CAT_STATES, "syncing state of element %s (%s) to %s (%s)",
|
||||||
GST_ELEMENT_NAME (element), gst_element_state_get_name (GST_STATE (element)),
|
GST_ELEMENT_NAME (element), gst_element_state_get_name (GST_STATE (element)),
|
||||||
GST_ELEMENT_NAME (parent), gst_element_state_get_name (GST_STATE (parent)));
|
GST_ELEMENT_NAME (parent), gst_element_state_get_name (GST_STATE (parent)));
|
||||||
if (gst_element_set_state (element, GST_STATE (parent)) == GST_STATE_FAILURE) {
|
if (gst_element_set_state (element, GST_STATE (parent)) == GST_STATE_FAILURE) {
|
||||||
|
@ -2240,13 +2239,13 @@ gst_element_set_state (GstElement *element, GstElementState state)
|
||||||
|
|
||||||
if (state == curpending)
|
if (state == curpending)
|
||||||
{
|
{
|
||||||
GST_DEBUG_ELEMENT (GST_CAT_STATES, element,
|
GST_CAT_DEBUG_OBJECT (GST_CAT_STATES, element,
|
||||||
"element is already in requested state %s",
|
"element is already in requested state %s",
|
||||||
gst_element_state_get_name (state));
|
gst_element_state_get_name (state));
|
||||||
return (GST_STATE_SUCCESS);
|
return (GST_STATE_SUCCESS);
|
||||||
}
|
}
|
||||||
|
|
||||||
GST_DEBUG_ELEMENT (GST_CAT_STATES, element, "setting state from %s to %s",
|
GST_CAT_DEBUG_OBJECT (GST_CAT_STATES, element, "setting state from %s to %s",
|
||||||
gst_element_state_get_name (curpending),
|
gst_element_state_get_name (curpending),
|
||||||
gst_element_state_get_name (state));
|
gst_element_state_get_name (state));
|
||||||
|
|
||||||
|
@ -2264,7 +2263,7 @@ gst_element_set_state (GstElement *element, GstElementState state)
|
||||||
GST_STATE_PENDING (element) = curpending;
|
GST_STATE_PENDING (element) = curpending;
|
||||||
|
|
||||||
if (curpending != state) {
|
if (curpending != state) {
|
||||||
GST_DEBUG_ELEMENT (GST_CAT_STATES, element,
|
GST_CAT_DEBUG_OBJECT (GST_CAT_STATES, element,
|
||||||
"intermediate: setting state from %s to %s",
|
"intermediate: setting state from %s to %s",
|
||||||
gst_element_state_get_name (GST_STATE (element)),
|
gst_element_state_get_name (GST_STATE (element)),
|
||||||
gst_element_state_get_name (curpending));
|
gst_element_state_get_name (curpending));
|
||||||
|
@ -2277,11 +2276,11 @@ gst_element_set_state (GstElement *element, GstElementState state)
|
||||||
|
|
||||||
switch (return_val) {
|
switch (return_val) {
|
||||||
case GST_STATE_FAILURE:
|
case GST_STATE_FAILURE:
|
||||||
GST_DEBUG_ELEMENT (GST_CAT_STATES, element,
|
GST_CAT_DEBUG_OBJECT (GST_CAT_STATES, element,
|
||||||
"have failed change_state return");
|
"have failed change_state return");
|
||||||
goto exit;
|
goto exit;
|
||||||
case GST_STATE_ASYNC:
|
case GST_STATE_ASYNC:
|
||||||
GST_DEBUG_ELEMENT (GST_CAT_STATES, element,
|
GST_CAT_DEBUG_OBJECT (GST_CAT_STATES, element,
|
||||||
"element will change state async");
|
"element will change state async");
|
||||||
goto exit;
|
goto exit;
|
||||||
case GST_STATE_SUCCESS:
|
case GST_STATE_SUCCESS:
|
||||||
|
@ -2314,7 +2313,7 @@ gst_element_negotiate_pads (GstElement *element)
|
||||||
{
|
{
|
||||||
GList *pads = GST_ELEMENT_PADS (element);
|
GList *pads = GST_ELEMENT_PADS (element);
|
||||||
|
|
||||||
GST_DEBUG_ELEMENT (GST_CAT_CAPS, element, "negotiating pads");
|
GST_CAT_DEBUG_OBJECT (GST_CAT_CAPS, element, "negotiating pads");
|
||||||
|
|
||||||
while (pads) {
|
while (pads) {
|
||||||
GstPad *pad = GST_PAD (pads->data);
|
GstPad *pad = GST_PAD (pads->data);
|
||||||
|
@ -2359,7 +2358,7 @@ gst_element_negotiate_pads (GstElement *element)
|
||||||
|
|
||||||
/* only try to negotiate if the peer element is in PAUSED or higher too */
|
/* only try to negotiate if the peer element is in PAUSED or higher too */
|
||||||
if (otherstate >= GST_STATE_READY) {
|
if (otherstate >= GST_STATE_READY) {
|
||||||
GST_DEBUG_ELEMENT (GST_CAT_CAPS, element,
|
GST_CAT_DEBUG_OBJECT (GST_CAT_CAPS, element,
|
||||||
"perform negotiate for %s:%s and %s:%s",
|
"perform negotiate for %s:%s and %s:%s",
|
||||||
GST_DEBUG_PAD_NAME (srcpad),
|
GST_DEBUG_PAD_NAME (srcpad),
|
||||||
GST_DEBUG_PAD_NAME (sinkpad));
|
GST_DEBUG_PAD_NAME (sinkpad));
|
||||||
|
@ -2367,7 +2366,7 @@ gst_element_negotiate_pads (GstElement *element)
|
||||||
return FALSE;
|
return FALSE;
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
GST_DEBUG_ELEMENT (GST_CAT_CAPS, element,
|
GST_CAT_DEBUG_OBJECT (GST_CAT_CAPS, element,
|
||||||
"not negotiating %s:%s and %s:%s, not in READY yet",
|
"not negotiating %s:%s and %s:%s, not in READY yet",
|
||||||
GST_DEBUG_PAD_NAME (srcpad),
|
GST_DEBUG_PAD_NAME (srcpad),
|
||||||
GST_DEBUG_PAD_NAME (sinkpad));
|
GST_DEBUG_PAD_NAME (sinkpad));
|
||||||
|
@ -2383,7 +2382,7 @@ gst_element_clear_pad_caps (GstElement *element)
|
||||||
{
|
{
|
||||||
GList *pads = GST_ELEMENT_PADS (element);
|
GList *pads = GST_ELEMENT_PADS (element);
|
||||||
|
|
||||||
GST_DEBUG_ELEMENT (GST_CAT_CAPS, element, "clearing pad caps");
|
GST_CAT_DEBUG_OBJECT (GST_CAT_CAPS, element, "clearing pad caps");
|
||||||
|
|
||||||
while (pads) {
|
while (pads) {
|
||||||
GstRealPad *pad = GST_PAD_REALIZE (pads->data);
|
GstRealPad *pad = GST_PAD_REALIZE (pads->data);
|
||||||
|
@ -2425,13 +2424,13 @@ gst_element_change_state (GstElement *element)
|
||||||
|
|
||||||
if (old_pending == GST_STATE_VOID_PENDING ||
|
if (old_pending == GST_STATE_VOID_PENDING ||
|
||||||
old_state == GST_STATE_PENDING (element)) {
|
old_state == GST_STATE_PENDING (element)) {
|
||||||
GST_INFO (GST_CAT_STATES,
|
GST_CAT_INFO (GST_CAT_STATES,
|
||||||
"no state change needed for element %s (VOID_PENDING)",
|
"no state change needed for element %s (VOID_PENDING)",
|
||||||
GST_ELEMENT_NAME (element));
|
GST_ELEMENT_NAME (element));
|
||||||
return GST_STATE_SUCCESS;
|
return GST_STATE_SUCCESS;
|
||||||
}
|
}
|
||||||
|
|
||||||
GST_INFO (GST_CAT_STATES, "%s default handler sets state from %s to %s %04x",
|
GST_CAT_INFO (GST_CAT_STATES, "%s default handler sets state from %s to %s %04x",
|
||||||
GST_ELEMENT_NAME (element),
|
GST_ELEMENT_NAME (element),
|
||||||
gst_element_state_get_name (old_state),
|
gst_element_state_get_name (old_state),
|
||||||
gst_element_state_get_name (old_pending),
|
gst_element_state_get_name (old_pending),
|
||||||
|
@ -2463,7 +2462,7 @@ gst_element_change_state (GstElement *element)
|
||||||
|
|
||||||
parent = GST_ELEMENT_PARENT (element);
|
parent = GST_ELEMENT_PARENT (element);
|
||||||
|
|
||||||
GST_DEBUG_ELEMENT (GST_CAT_STATES, element,
|
GST_CAT_DEBUG_OBJECT (GST_CAT_STATES, element,
|
||||||
"signaling state change from %s to %s",
|
"signaling state change from %s to %s",
|
||||||
gst_element_state_get_name (old_state),
|
gst_element_state_get_name (old_state),
|
||||||
gst_element_state_get_name (GST_STATE (element)));
|
gst_element_state_get_name (GST_STATE (element)));
|
||||||
|
@ -2472,7 +2471,7 @@ gst_element_change_state (GstElement *element)
|
||||||
if (element->sched) {
|
if (element->sched) {
|
||||||
if (gst_scheduler_state_transition (element->sched, element,
|
if (gst_scheduler_state_transition (element->sched, element,
|
||||||
old_transition) != GST_STATE_SUCCESS) {
|
old_transition) != GST_STATE_SUCCESS) {
|
||||||
GST_DEBUG_ELEMENT (GST_CAT_STATES, element,
|
GST_CAT_DEBUG_OBJECT (GST_CAT_STATES, element,
|
||||||
"scheduler could not change state");
|
"scheduler could not change state");
|
||||||
goto failure;
|
goto failure;
|
||||||
}
|
}
|
||||||
|
@ -2526,7 +2525,7 @@ gst_element_dispose (GObject *object)
|
||||||
GList *pads;
|
GList *pads;
|
||||||
GstPad *pad;
|
GstPad *pad;
|
||||||
|
|
||||||
GST_DEBUG_ELEMENT (GST_CAT_REFCOUNTING, element, "dispose");
|
GST_CAT_DEBUG_OBJECT (GST_CAT_REFCOUNTING, element, "dispose");
|
||||||
|
|
||||||
gst_element_set_state (element, GST_STATE_NULL);
|
gst_element_set_state (element, GST_STATE_NULL);
|
||||||
|
|
||||||
|
@ -2538,7 +2537,7 @@ gst_element_dispose (GObject *object)
|
||||||
pad = GST_PAD (pads->data);
|
pad = GST_PAD (pads->data);
|
||||||
|
|
||||||
if (GST_PAD_PEER (pad)) {
|
if (GST_PAD_PEER (pad)) {
|
||||||
GST_DEBUG (GST_CAT_REFCOUNTING, "unlinking pad '%s'",
|
GST_CAT_DEBUG (GST_CAT_REFCOUNTING, "unlinking pad '%s'",
|
||||||
GST_OBJECT_NAME (GST_OBJECT (GST_PAD (GST_PAD_PEER (pad)))));
|
GST_OBJECT_NAME (GST_OBJECT (GST_PAD (GST_PAD_PEER (pad)))));
|
||||||
gst_pad_unlink (pad, GST_PAD (GST_PAD_PEER (pad)));
|
gst_pad_unlink (pad, GST_PAD (GST_PAD_PEER (pad)));
|
||||||
}
|
}
|
||||||
|
@ -2751,7 +2750,7 @@ gst_element_set_scheduler (GstElement *element,
|
||||||
{
|
{
|
||||||
g_return_if_fail (GST_IS_ELEMENT (element));
|
g_return_if_fail (GST_IS_ELEMENT (element));
|
||||||
|
|
||||||
GST_INFO_ELEMENT (GST_CAT_PARENTAGE, element, "setting scheduler to %p", sched);
|
GST_CAT_INFO_OBJECT (GST_CAT_PARENTAGE, element, "setting scheduler to %p", sched);
|
||||||
|
|
||||||
gst_object_replace ((GstObject **)&GST_ELEMENT_SCHED (element), GST_OBJECT (sched));
|
gst_object_replace ((GstObject **)&GST_ELEMENT_SCHED (element), GST_OBJECT (sched));
|
||||||
}
|
}
|
||||||
|
@ -2821,7 +2820,7 @@ gst_element_set_eos_recursive (GstElement *element)
|
||||||
parent that's PAUSED was PLAYING before. That means it has reached EOS. */
|
parent that's PAUSED was PLAYING before. That means it has reached EOS. */
|
||||||
GstElement *parent;
|
GstElement *parent;
|
||||||
|
|
||||||
GST_DEBUG (GST_CAT_EVENT, "setting recursive EOS on %s",
|
GST_CAT_DEBUG (GST_CAT_EVENT, "setting recursive EOS on %s",
|
||||||
GST_OBJECT_NAME (element));
|
GST_OBJECT_NAME (element));
|
||||||
g_signal_emit (G_OBJECT (element), gst_element_signals[EOS], 0);
|
g_signal_emit (G_OBJECT (element), gst_element_signals[EOS], 0);
|
||||||
|
|
||||||
|
@ -2843,7 +2842,7 @@ gst_element_set_eos (GstElement *element)
|
||||||
{
|
{
|
||||||
g_return_if_fail (GST_IS_ELEMENT (element));
|
g_return_if_fail (GST_IS_ELEMENT (element));
|
||||||
|
|
||||||
GST_DEBUG (GST_CAT_EVENT, "setting EOS on element %s",
|
GST_CAT_DEBUG (GST_CAT_EVENT, "setting EOS on element %s",
|
||||||
GST_OBJECT_NAME (element));
|
GST_OBJECT_NAME (element));
|
||||||
|
|
||||||
if (GST_STATE (element) == GST_STATE_PLAYING) {
|
if (GST_STATE (element) == GST_STATE_PLAYING) {
|
||||||
|
|
|
@ -20,12 +20,11 @@
|
||||||
* Boston, MA 02111-1307, USA.
|
* Boston, MA 02111-1307, USA.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
/* #define DEBUG_ENABLED */
|
|
||||||
#include "gst_private.h"
|
#include "gst_private.h"
|
||||||
|
|
||||||
#include "gstelement.h"
|
#include "gstelement.h"
|
||||||
#include "gstregistrypool.h"
|
#include "gstregistrypool.h"
|
||||||
#include "gstlog.h"
|
#include "gstinfo.h"
|
||||||
|
|
||||||
static void gst_element_factory_class_init (GstElementFactoryClass *klass);
|
static void gst_element_factory_class_init (GstElementFactoryClass *klass);
|
||||||
static void gst_element_factory_init (GstElementFactory *factory);
|
static void gst_element_factory_init (GstElementFactory *factory);
|
||||||
|
@ -103,7 +102,7 @@ gst_element_factory_find (const gchar *name)
|
||||||
return GST_ELEMENT_FACTORY (feature);
|
return GST_ELEMENT_FACTORY (feature);
|
||||||
|
|
||||||
/* this should be an ERROR */
|
/* this should be an ERROR */
|
||||||
GST_DEBUG (GST_CAT_ELEMENT_FACTORY,"no such elementfactory \"%s\"", name);
|
GST_CAT_DEBUG (GST_CAT_ELEMENT_FACTORY,"no such elementfactory \"%s\"", name);
|
||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -212,7 +211,7 @@ gst_element_factory_create (GstElementFactory *factory,
|
||||||
if (!gst_plugin_feature_ensure_loaded (GST_PLUGIN_FEATURE (factory)))
|
if (!gst_plugin_feature_ensure_loaded (GST_PLUGIN_FEATURE (factory)))
|
||||||
return NULL;
|
return NULL;
|
||||||
|
|
||||||
GST_DEBUG (GST_CAT_ELEMENT_FACTORY,
|
GST_CAT_DEBUG (GST_CAT_ELEMENT_FACTORY,
|
||||||
"creating element from factory \"%s\" (name \"%s\", type %d)",
|
"creating element from factory \"%s\" (name \"%s\", type %d)",
|
||||||
GST_PLUGIN_FEATURE_NAME (factory), GST_STR_NULL (name), (gint) factory->type);
|
GST_PLUGIN_FEATURE_NAME (factory), GST_STR_NULL (name), (gint) factory->type);
|
||||||
|
|
||||||
|
@ -225,7 +224,7 @@ gst_element_factory_create (GstElementFactory *factory,
|
||||||
/* attempt to set the elementfactory class pointer if necessary */
|
/* attempt to set the elementfactory class pointer if necessary */
|
||||||
oclass = GST_ELEMENT_CLASS (g_type_class_ref (factory->type));
|
oclass = GST_ELEMENT_CLASS (g_type_class_ref (factory->type));
|
||||||
if (oclass->elementfactory == NULL) {
|
if (oclass->elementfactory == NULL) {
|
||||||
GST_DEBUG (GST_CAT_ELEMENT_FACTORY, "class %s", GST_PLUGIN_FEATURE_NAME (factory));
|
GST_CAT_DEBUG (GST_CAT_ELEMENT_FACTORY, "class %s", GST_PLUGIN_FEATURE_NAME (factory));
|
||||||
oclass->elementfactory = factory;
|
oclass->elementfactory = factory;
|
||||||
|
|
||||||
/* copy pad template pointers to the element class,
|
/* copy pad template pointers to the element class,
|
||||||
|
@ -266,19 +265,19 @@ gst_element_factory_make (const gchar *factoryname, const gchar *name)
|
||||||
|
|
||||||
g_return_val_if_fail (factoryname != NULL, NULL);
|
g_return_val_if_fail (factoryname != NULL, NULL);
|
||||||
|
|
||||||
GST_DEBUG (GST_CAT_ELEMENT_FACTORY, "gstelementfactory: make \"%s\" \"%s\"",
|
GST_CAT_DEBUG (GST_CAT_ELEMENT_FACTORY, "gstelementfactory: make \"%s\" \"%s\"",
|
||||||
factoryname, GST_STR_NULL (name));
|
factoryname, GST_STR_NULL (name));
|
||||||
|
|
||||||
/* gst_plugin_load_element_factory (factoryname); */
|
/* gst_plugin_load_element_factory (factoryname); */
|
||||||
factory = gst_element_factory_find (factoryname);
|
factory = gst_element_factory_find (factoryname);
|
||||||
if (factory == NULL) {
|
if (factory == NULL) {
|
||||||
GST_INFO (GST_CAT_ELEMENT_FACTORY,"no such element factory \"%s\"!",
|
GST_CAT_INFO (GST_CAT_ELEMENT_FACTORY,"no such element factory \"%s\"!",
|
||||||
factoryname);
|
factoryname);
|
||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
element = gst_element_factory_create (factory, name);
|
element = gst_element_factory_create (factory, name);
|
||||||
if (element == NULL) {
|
if (element == NULL) {
|
||||||
GST_INFO (GST_CAT_ELEMENT_FACTORY,
|
GST_CAT_INFO (GST_CAT_ELEMENT_FACTORY,
|
||||||
"couldn't create instance of element factory \"%s\"!",
|
"couldn't create instance of element factory \"%s\"!",
|
||||||
factoryname);
|
factoryname);
|
||||||
return NULL;
|
return NULL;
|
||||||
|
|
|
@ -22,12 +22,13 @@
|
||||||
|
|
||||||
#include <string.h> /* memcpy */
|
#include <string.h> /* memcpy */
|
||||||
|
|
||||||
#include "gstinfo.h"
|
#include "gst_private.h"
|
||||||
#include "gstdata_private.h"
|
#include "gstdata_private.h"
|
||||||
|
|
||||||
|
#include "gstinfo.h"
|
||||||
#include "gstmemchunk.h"
|
#include "gstmemchunk.h"
|
||||||
#include "gstevent.h"
|
#include "gstevent.h"
|
||||||
#include "gstlog.h"
|
#include "gstlog.h"
|
||||||
|
|
||||||
#ifndef GST_DISABLE_TRACE
|
#ifndef GST_DISABLE_TRACE
|
||||||
/* #define GST_WITH_ALLOC_TRACE */
|
/* #define GST_WITH_ALLOC_TRACE */
|
||||||
#include "gsttrace.h"
|
#include "gsttrace.h"
|
||||||
|
@ -76,7 +77,7 @@ _gst_event_copy (GstEvent *event)
|
||||||
static void
|
static void
|
||||||
_gst_event_free (GstEvent* event)
|
_gst_event_free (GstEvent* event)
|
||||||
{
|
{
|
||||||
GST_INFO (GST_CAT_EVENT, "freeing event %p", event);
|
GST_CAT_INFO (GST_CAT_EVENT, "freeing event %p", event);
|
||||||
|
|
||||||
if (GST_EVENT_SRC (event)) {
|
if (GST_EVENT_SRC (event)) {
|
||||||
gst_object_unref (GST_EVENT_SRC (event));
|
gst_object_unref (GST_EVENT_SRC (event));
|
||||||
|
@ -144,7 +145,7 @@ gst_event_new (GstEventType type)
|
||||||
gst_alloc_trace_new (_event_trace, event);
|
gst_alloc_trace_new (_event_trace, event);
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
GST_INFO (GST_CAT_EVENT, "creating new event %p %d", event, type);
|
GST_CAT_INFO (GST_CAT_EVENT, "creating new event %p %d", event, type);
|
||||||
|
|
||||||
_GST_DATA_INIT (GST_DATA (event),
|
_GST_DATA_INIT (GST_DATA (event),
|
||||||
_gst_event_type,
|
_gst_event_type,
|
||||||
|
|
|
@ -20,10 +20,10 @@
|
||||||
* Boston, MA 02111-1307, USA.
|
* Boston, MA 02111-1307, USA.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#include "gstlog.h"
|
|
||||||
#include "gst_private.h"
|
#include "gst_private.h"
|
||||||
#include "gstregistrypool.h"
|
|
||||||
|
|
||||||
|
#include "gstinfo.h"
|
||||||
|
#include "gstregistrypool.h"
|
||||||
#include "gstpad.h"
|
#include "gstpad.h"
|
||||||
#include "gstindex.h"
|
#include "gstindex.h"
|
||||||
|
|
||||||
|
@ -152,7 +152,7 @@ gst_index_init (GstIndex *index)
|
||||||
GST_FLAG_SET (index, GST_INDEX_WRITABLE);
|
GST_FLAG_SET (index, GST_INDEX_WRITABLE);
|
||||||
GST_FLAG_SET (index, GST_INDEX_READABLE);
|
GST_FLAG_SET (index, GST_INDEX_READABLE);
|
||||||
|
|
||||||
GST_DEBUG(0, "created new index");
|
GST_DEBUG ( "created new index");
|
||||||
}
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
|
@ -203,7 +203,7 @@ gst_index_group_new(guint groupnum)
|
||||||
indexgroup->certainty = GST_INDEX_UNKNOWN;
|
indexgroup->certainty = GST_INDEX_UNKNOWN;
|
||||||
indexgroup->peergroup = -1;
|
indexgroup->peergroup = -1;
|
||||||
|
|
||||||
GST_DEBUG(0, "created new index group %d",groupnum);
|
GST_DEBUG ( "created new index group %d",groupnum);
|
||||||
|
|
||||||
return indexgroup;
|
return indexgroup;
|
||||||
}
|
}
|
||||||
|
@ -274,7 +274,7 @@ gst_index_new_group(GstIndex *index)
|
||||||
{
|
{
|
||||||
index->curgroup = gst_index_group_new(++index->maxgroup);
|
index->curgroup = gst_index_group_new(++index->maxgroup);
|
||||||
index->groups = g_list_append(index->groups,index->curgroup);
|
index->groups = g_list_append(index->groups,index->curgroup);
|
||||||
GST_DEBUG(0, "created new group %d in index",index->maxgroup);
|
GST_DEBUG ( "created new group %d in index",index->maxgroup);
|
||||||
return index->maxgroup;
|
return index->maxgroup;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -305,13 +305,13 @@ gst_index_set_group(GstIndex *index, gint groupnum)
|
||||||
list = g_list_next(list);
|
list = g_list_next(list);
|
||||||
if (indexgroup->groupnum == groupnum) {
|
if (indexgroup->groupnum == groupnum) {
|
||||||
index->curgroup = indexgroup;
|
index->curgroup = indexgroup;
|
||||||
GST_DEBUG(0, "switched to index group %d", indexgroup->groupnum);
|
GST_DEBUG ( "switched to index group %d", indexgroup->groupnum);
|
||||||
return TRUE;
|
return TRUE;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/* couldn't find the group in question */
|
/* couldn't find the group in question */
|
||||||
GST_DEBUG(0, "couldn't find index group %d",groupnum);
|
GST_DEBUG ( "couldn't find index group %d",groupnum);
|
||||||
return FALSE;
|
return FALSE;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -892,7 +892,7 @@ gst_index_factory_find (const gchar *name)
|
||||||
|
|
||||||
g_return_val_if_fail (name != NULL, NULL);
|
g_return_val_if_fail (name != NULL, NULL);
|
||||||
|
|
||||||
GST_DEBUG (0,"gstindex: find \"%s\"", name);
|
GST_DEBUG ("gstindex: find \"%s\"", name);
|
||||||
|
|
||||||
feature = gst_registry_pool_find_feature (name, GST_TYPE_INDEX_FACTORY);
|
feature = gst_registry_pool_find_feature (name, GST_TYPE_INDEX_FACTORY);
|
||||||
if (feature)
|
if (feature)
|
||||||
|
@ -949,4 +949,3 @@ gst_index_factory_make (const gchar *name)
|
||||||
|
|
||||||
return gst_index_factory_create (factory);
|
return gst_index_factory_create (factory);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
1179
gst/gstinfo.c
1179
gst/gstinfo.c
File diff suppressed because it is too large
Load diff
865
gst/gstinfo.h
865
gst/gstinfo.h
|
@ -1,8 +1,9 @@
|
||||||
/* GStreamer
|
/* GStreamer
|
||||||
* Copyright (C) 1999,2000 Erik Walthinsen <omega@cse.ogi.edu>
|
* Copyright (C) 1999,2000 Erik Walthinsen <omega@cse.ogi.edu>
|
||||||
* 2000 Wim Taymans <wtay@chello.be>
|
* 2000 Wim Taymans <wtay@chello.be>
|
||||||
|
* 2003 Benjamin Otte <in7y118@public.uni-hamburg.de>
|
||||||
*
|
*
|
||||||
* gstinfo.h:
|
* gstinfo.h: debugging functions
|
||||||
*
|
*
|
||||||
* 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
|
||||||
|
@ -23,454 +24,522 @@
|
||||||
#ifndef __GSTINFO_H__
|
#ifndef __GSTINFO_H__
|
||||||
#define __GSTINFO_H__
|
#define __GSTINFO_H__
|
||||||
|
|
||||||
#include <stdio.h>
|
#include <glib.h>
|
||||||
#include <gmodule.h>
|
#include <glib-object.h>
|
||||||
#include <unistd.h>
|
#include <gst/gstatomic.h>
|
||||||
#include <glib/gmacros.h>
|
#include <gst/gstlog.h>
|
||||||
|
#include <gst/gstconfig.h>
|
||||||
|
|
||||||
#ifdef HAVE_CONFIG_H
|
/*
|
||||||
#include <config.h>
|
* GStreamer's debugging subsystem is an easy way to get information about what
|
||||||
|
* the application is doing.
|
||||||
|
* It is not meant for programming errors. Use GLibs methods (g_warning and so
|
||||||
|
* on for that.
|
||||||
|
*/
|
||||||
|
|
||||||
|
/* log levels */
|
||||||
|
typedef enum {
|
||||||
|
GST_LEVEL_NONE = 0,
|
||||||
|
GST_LEVEL_ERROR,
|
||||||
|
GST_LEVEL_WARNING,
|
||||||
|
GST_LEVEL_INFO,
|
||||||
|
GST_LEVEL_DEBUG,
|
||||||
|
GST_LEVEL_LOG,
|
||||||
|
/* add more */
|
||||||
|
GST_LEVEL_COUNT
|
||||||
|
} GstDebugLevel;
|
||||||
|
|
||||||
|
/* we can now override this to be more general in maintainer builds or cvs checkouts */
|
||||||
|
#ifndef GST_LEVEL_DEFAULT
|
||||||
|
#define GST_LEVEL_DEFAULT GST_LEVEL_ERROR
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
/* defines for format (colors etc) - don't change them around, it uses terminal layout
|
||||||
|
* Terminal color strings:
|
||||||
|
* 00=none 01=bold 04=underscore 05=blink 07=reverse 08=concealed
|
||||||
|
* Text color codes:
|
||||||
|
* 30=black 31=red 32=green 33=yellow 34=blue 35=magenta 36=cyan 37=white
|
||||||
|
* Background color codes:
|
||||||
|
* 40=black 41=red 42=green 43=yellow 44=blue 45=magenta 46=cyan 47=white
|
||||||
|
*/
|
||||||
|
typedef enum {
|
||||||
|
/* colors */
|
||||||
|
GST_DEBUG_FG_BLACK = 0x0000,
|
||||||
|
GST_DEBUG_FG_RED = 0x0001,
|
||||||
|
GST_DEBUG_FG_GREEN = 0x0002,
|
||||||
|
GST_DEBUG_FG_YELLOW = 0x0003,
|
||||||
|
GST_DEBUG_FG_BLUE = 0x0004,
|
||||||
|
GST_DEBUG_FG_MAGENTA = 0x0005,
|
||||||
|
GST_DEBUG_FG_CYAN = 0x0006,
|
||||||
|
GST_DEBUG_FG_WHITE = 0x0007,
|
||||||
|
/* background colors */
|
||||||
|
GST_DEBUG_BG_BLACK = 0x0000,
|
||||||
|
GST_DEBUG_BG_RED = 0x0010,
|
||||||
|
GST_DEBUG_BG_GREEN = 0x0020,
|
||||||
|
GST_DEBUG_BG_YELLOW = 0x0030,
|
||||||
|
GST_DEBUG_BG_BLUE = 0x0040,
|
||||||
|
GST_DEBUG_BG_MAGENTA = 0x0050,
|
||||||
|
GST_DEBUG_BG_CYAN = 0x0060,
|
||||||
|
GST_DEBUG_BG_WHITE = 0x0070,
|
||||||
|
/* other formats */
|
||||||
|
GST_DEBUG_BOLD = 0x0100,
|
||||||
|
GST_DEBUG_UNDERLINE = 0x0200
|
||||||
|
} GstDebugColorFlags;
|
||||||
|
|
||||||
|
#define GST_DEBUG_FG_MASK (0x000F)
|
||||||
|
#define GST_DEBUG_BG_MASK (0x00F0)
|
||||||
|
#define GST_DEBUG_FORMAT_MASK (0xFF00)
|
||||||
|
|
||||||
|
typedef struct _GstDebugCategory GstDebugCategory;
|
||||||
|
struct _GstDebugCategory {
|
||||||
|
/*< private >*/
|
||||||
|
GstAtomicInt * threshold;
|
||||||
|
guint color; /* see defines above */
|
||||||
|
|
||||||
|
const gchar * name;
|
||||||
|
const gchar * description;
|
||||||
|
};
|
||||||
|
|
||||||
|
/********** some convenience macros for debugging **********/
|
||||||
|
|
||||||
/* This is needed in printf's if a char* might be NULL. Solaris crashes then */
|
/* This is needed in printf's if a char* might be NULL. Solaris crashes then */
|
||||||
#define GST_STR_NULL(str) ((str) ? (str) : "(NULL)")
|
#define GST_STR_NULL(str) ((str) ? (str) : "(NULL)")
|
||||||
|
|
||||||
/* FIXME: convert to using G_STRLOC all the way if we can ! */
|
/* easier debugging for pad names */
|
||||||
|
|
||||||
#ifndef FUNCTION
|
|
||||||
#ifdef G_GNUC_PRETTY_FUNCTION
|
|
||||||
#define FUNCTION G_GNUC_PRETTY_FUNCTION
|
|
||||||
#elif HAVE_FUNC
|
|
||||||
#define FUNCTION __func__
|
|
||||||
#elif HAVE_PRETTY_FUNCTION
|
|
||||||
#define FUNCTION __PRETTY_FUNCTION__
|
|
||||||
#elif HAVE_FUNCTION
|
|
||||||
#define FUNCTION __FUNCTION__
|
|
||||||
#else
|
|
||||||
#define FUNCTION ""
|
|
||||||
#endif
|
|
||||||
#endif /* ifndef FUNCTION */
|
|
||||||
|
|
||||||
/***** are we in the core or not? *****/
|
|
||||||
#ifdef __GST_PRIVATE_H__
|
|
||||||
#define _GST_DEBUG_INCORE TRUE
|
|
||||||
#else
|
|
||||||
#define _GST_DEBUG_INCORE FALSE
|
|
||||||
#endif
|
|
||||||
|
|
||||||
|
|
||||||
/* colorization stuff */
|
|
||||||
#ifdef GST_DEBUG_COLOR
|
|
||||||
#ifdef __GST_PRIVATE_H__ /* FIXME this should be some libgst.la -specific thing */
|
|
||||||
#define GST_DEBUG_CHAR_MODE "00"
|
|
||||||
#else
|
|
||||||
#define GST_DEBUG_CHAR_MODE "01"
|
|
||||||
#endif
|
|
||||||
#endif
|
|
||||||
|
|
||||||
gint _gst_debug_stringhash_color(gchar *file);
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
/**********************************************************************
|
|
||||||
* Categories
|
|
||||||
**********************************************************************/
|
|
||||||
|
|
||||||
const gchar * gst_get_category_name (gint category);
|
|
||||||
|
|
||||||
enum {
|
|
||||||
GST_CAT_GST_INIT = 0, /* Library initialization */
|
|
||||||
GST_CAT_COTHREADS, /* Cothread creation, etc. */
|
|
||||||
GST_CAT_COTHREAD_SWITCH, /* Cothread switching */
|
|
||||||
GST_CAT_AUTOPLUG, /* Successful autoplug results */
|
|
||||||
GST_CAT_AUTOPLUG_ATTEMPT, /* Attempted autoplug operations */
|
|
||||||
GST_CAT_PARENTAGE, /* GstBin parentage issues */
|
|
||||||
GST_CAT_STATES, /* State changes and such */
|
|
||||||
GST_CAT_PLANNING, /* Plan generation */
|
|
||||||
GST_CAT_SCHEDULING, /* Schedule construction */
|
|
||||||
GST_CAT_DATAFLOW, /* Events during actual data movement */
|
|
||||||
GST_CAT_BUFFER, /* Buffer creation/destruction */
|
|
||||||
GST_CAT_CAPS, /* Capabilities matching */
|
|
||||||
GST_CAT_CLOCK, /* Clocking */
|
|
||||||
GST_CAT_ELEMENT_PADS, /* Element pad management */
|
|
||||||
GST_CAT_ELEMENT_FACTORY, /* Elementfactory stuff */
|
|
||||||
GST_CAT_PADS, /* Pad creation/linking */
|
|
||||||
GST_CAT_PIPELINE, /* Pipeline stuff */
|
|
||||||
GST_CAT_PLUGIN_LOADING, /* Plugin loading */
|
|
||||||
GST_CAT_PLUGIN_ERRORS, /* Errors during plugin loading */
|
|
||||||
GST_CAT_PLUGIN_INFO, /* Plugin state information */
|
|
||||||
GST_CAT_PROPERTIES, /* Properties */
|
|
||||||
GST_CAT_THREAD, /* Thread creation/management */
|
|
||||||
GST_CAT_TYPES, /* Typing */
|
|
||||||
GST_CAT_XML, /* XML load/save of everything */
|
|
||||||
GST_CAT_NEGOTIATION, /* Caps Negotiation stuff */
|
|
||||||
GST_CAT_REFCOUNTING, /* Ref Counting stuff */
|
|
||||||
GST_CAT_EVENT, /* Event system */
|
|
||||||
GST_CAT_PARAMS, /* Dynamic parameters */
|
|
||||||
GST_CAT_APPLICATION, /* Application-defined debugging */
|
|
||||||
|
|
||||||
GST_CAT_CALL_TRACE = 30, /* Call tracing */
|
|
||||||
|
|
||||||
GST_CAT_MAX_CATEGORY = 31
|
|
||||||
};
|
|
||||||
|
|
||||||
extern const gchar *_gst_category_colors[32];
|
|
||||||
|
|
||||||
extern GStaticPrivate _gst_debug_cothread_index;
|
|
||||||
|
|
||||||
|
|
||||||
/**********************************************************************
|
|
||||||
* DEBUG system
|
|
||||||
**********************************************************************/
|
|
||||||
|
|
||||||
/* for include files that make too much noise normally */
|
|
||||||
#ifdef GST_DEBUG_FORCE_DISABLE
|
|
||||||
#undef GST_DEBUG_ENABLED
|
|
||||||
#endif
|
|
||||||
/* for applications that really really want all the noise */
|
|
||||||
#ifdef GST_DEBUG_FORCE_ENABLE
|
|
||||||
#define GST_DEBUG_ENABLED
|
|
||||||
#endif
|
|
||||||
|
|
||||||
/*#ifdef GST_DEBUG_ENABLED */
|
|
||||||
#define GST_DEBUG_ENABLE_CATEGORIES 0xffffffff
|
|
||||||
/*#else */
|
|
||||||
/*#define GST_DEBUG_ENABLE_CATEGORIES 0x00000000 */
|
|
||||||
/*#endif */
|
|
||||||
|
|
||||||
|
|
||||||
typedef void (*GstDebugHandler) (gint category,gboolean core,
|
|
||||||
const gchar *file,const gchar *function,
|
|
||||||
gint line,const gchar *debug_string,
|
|
||||||
void *element,gchar *string);
|
|
||||||
|
|
||||||
void gst_default_debug_handler (gint category,gboolean incore,
|
|
||||||
const gchar *file, const gchar *function,
|
|
||||||
gint line,const gchar *debug_string,
|
|
||||||
void *element,gchar *string);
|
|
||||||
|
|
||||||
extern guint32 _gst_debug_categories;
|
|
||||||
extern GstDebugHandler _gst_debug_handler;
|
|
||||||
|
|
||||||
/* fallback, this should probably be a 'weak' symbol or something */
|
|
||||||
G_GNUC_UNUSED static gchar *_debug_string = NULL;
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
#ifdef G_HAVE_ISO_VARARGS
|
|
||||||
|
|
||||||
#ifdef GST_DEBUG_ENABLED
|
|
||||||
#define GST_DEBUG(cat, ...) G_STMT_START{ \
|
|
||||||
if ((1<<cat) & _gst_debug_categories) \
|
|
||||||
_gst_debug_handler(cat,_GST_DEBUG_INCORE,__FILE__,FUNCTION,__LINE__,_debug_string, \
|
|
||||||
NULL,g_strdup_printf( __VA_ARGS__ )); \
|
|
||||||
}G_STMT_END
|
|
||||||
|
|
||||||
#define GST_DEBUG_ELEMENT(cat, element, ...) G_STMT_START{ \
|
|
||||||
if ((1<<cat) & _gst_debug_categories) \
|
|
||||||
_gst_debug_handler(cat,_GST_DEBUG_INCORE,__FILE__,FUNCTION,__LINE__,_debug_string, \
|
|
||||||
element,g_strdup_printf( __VA_ARGS__ )); \
|
|
||||||
}G_STMT_END
|
|
||||||
|
|
||||||
#else
|
|
||||||
#define GST_DEBUG(cat, ...)
|
|
||||||
#define GST_DEBUG_ELEMENT(cat,element, ...)
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#elif defined(G_HAVE_GNUC_VARARGS)
|
|
||||||
|
|
||||||
#ifdef GST_DEBUG_ENABLED
|
|
||||||
#define GST_DEBUG(cat,format,args...) G_STMT_START{ \
|
|
||||||
if ((1<<cat) & _gst_debug_categories) \
|
|
||||||
_gst_debug_handler(cat,_GST_DEBUG_INCORE,__FILE__,FUNCTION,__LINE__,_debug_string, \
|
|
||||||
NULL,g_strdup_printf( format , ## args )); \
|
|
||||||
}G_STMT_END
|
|
||||||
|
|
||||||
#define GST_DEBUG_ELEMENT(cat,element,format,args...) G_STMT_START{ \
|
|
||||||
if ((1<<cat) & _gst_debug_categories) \
|
|
||||||
_gst_debug_handler(cat,_GST_DEBUG_INCORE,__FILE__,FUNCTION,__LINE__,_debug_string, \
|
|
||||||
element,g_strdup_printf( format , ## args )); \
|
|
||||||
}G_STMT_END
|
|
||||||
|
|
||||||
#else
|
|
||||||
#define GST_DEBUG(cat,format,args...)
|
|
||||||
#define GST_DEBUG_ELEMENT(cat,element,format,args...)
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#endif
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
/********** some convenience macros for debugging **********/
|
|
||||||
#define GST_DEBUG_PAD_NAME(pad) \
|
#define GST_DEBUG_PAD_NAME(pad) \
|
||||||
(GST_OBJECT_PARENT(pad) != NULL) ? \
|
(GST_OBJECT_PARENT(pad) != NULL) ? \
|
||||||
GST_STR_NULL (GST_OBJECT_NAME (GST_OBJECT_PARENT(pad))) : \
|
GST_STR_NULL (GST_OBJECT_NAME (GST_OBJECT_PARENT(pad))) : \
|
||||||
"''", GST_OBJECT_NAME (pad)
|
"''", GST_OBJECT_NAME (pad)
|
||||||
|
|
||||||
#ifdef G_HAVE_ISO_VARARGS
|
/* You might want to define GST_FUNCTION in apps' configure script */
|
||||||
|
|
||||||
#ifdef GST_DEBUG_COLOR
|
#ifndef GST_FUNCTION
|
||||||
#define GST_DEBUG_ENTER(...) GST_DEBUG( 31 , "\033[00;37mentering\033[00m: " __VA_ARGS__ )
|
#ifdef G_GNUC_PRETTY_FUNCTION
|
||||||
#define GST_DEBUG_LEAVE(...) GST_DEBUG( 31 , "\033[00;37mleaving\033[00m: " __VA_ARGS__ )
|
#define GST_FUNCTION G_GNUC_PRETTY_FUNCTION
|
||||||
|
#elif HAVE_FUNC
|
||||||
|
#define GST_FUNCTION __func__
|
||||||
|
#elif HAVE_PRETTY_FUNCTION
|
||||||
|
#define GST_FUNCTION __PRETTY_FUNCTION__
|
||||||
|
#elif HAVE_FUNCTION
|
||||||
|
#define GST_FUNCTION __FUNCTION__
|
||||||
#else
|
#else
|
||||||
#define GST_DEBUG_ENTER(...) GST_DEBUG( 31 , "entering: " __VA_ARGS__ )
|
#define GST_FUNCTION ""
|
||||||
#define GST_DEBUG_LEAVE(...) GST_DEBUG( 31 , "leaving: " __VA_ARGS__ )
|
#endif
|
||||||
|
#endif /* ifndef GST_FUNCTION */
|
||||||
|
|
||||||
|
typedef void (*GstLogFunction) (GstDebugCategory * category,
|
||||||
|
GstDebugLevel level,
|
||||||
|
const gchar * file,
|
||||||
|
const gchar * function,
|
||||||
|
gint line,
|
||||||
|
GObject * object,
|
||||||
|
gchar * message,
|
||||||
|
gpointer data);
|
||||||
|
|
||||||
|
/* Disable this subsystem if no varargs macro can be found.
|
||||||
|
Use a trick so the core builds the functions nonetheless if it wasn't
|
||||||
|
explicitly disabled. */
|
||||||
|
#if !defined(G_HAVE_ISO_VARARGS) && !defined(G_HAVE_GNUC_VARARGS)
|
||||||
|
#define __GST_DISABLE_GST_DEBUG
|
||||||
|
#endif
|
||||||
|
#ifdef GST_DISABLE_GST_DEBUG
|
||||||
|
#ifndef __GST_DISABLE_GST_DEBUG
|
||||||
|
#define __GST_DISABLE_GST_DEBUG
|
||||||
|
#endif
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#elif defined(G_HAVE_GNUC_VARARGS)
|
#ifndef __GST_DISABLE_GST_DEBUG
|
||||||
|
|
||||||
#ifdef GST_DEBUG_COLOR
|
void _gst_debug_init (void);
|
||||||
#define GST_DEBUG_ENTER(format, args...) GST_DEBUG( 31 , format ": \033[00;37mentering\033[00m" , ##args )
|
|
||||||
#define GST_DEBUG_LEAVE(format, args...) GST_DEBUG( 31 , format ": \033[00;37mleaving\033[00m" , ##args )
|
|
||||||
#else
|
|
||||||
#define GST_DEBUG_ENTER(format, args...) GST_DEBUG( 31 , format ": entering" , ##args )
|
|
||||||
#define GST_DEBUG_LEAVE(format, args...) GST_DEBUG( 31 , format ": leaving" , ##args )
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#endif
|
void gst_debug_log (GstDebugCategory * category,
|
||||||
|
GstDebugLevel level,
|
||||||
|
const gchar * file,
|
||||||
|
const gchar * function,
|
||||||
|
gint line,
|
||||||
|
GObject * object,
|
||||||
|
gchar * format,
|
||||||
|
...) G_GNUC_PRINTF (7, 8) G_GNUC_NO_INSTRUMENT;
|
||||||
|
void gst_debug_logv (GstDebugCategory * category,
|
||||||
|
GstDebugLevel level,
|
||||||
|
const gchar * file,
|
||||||
|
const gchar * function,
|
||||||
|
gint line,
|
||||||
|
GObject * object,
|
||||||
|
gchar * format,
|
||||||
|
va_list args) G_GNUC_NO_INSTRUMENT;
|
||||||
|
|
||||||
|
void gst_debug_log_default (GstDebugCategory * category,
|
||||||
|
GstDebugLevel level,
|
||||||
|
const gchar * file,
|
||||||
|
const gchar * function,
|
||||||
|
gint line,
|
||||||
|
GObject * object,
|
||||||
|
gchar * message,
|
||||||
|
gpointer unused) G_GNUC_NO_INSTRUMENT;
|
||||||
|
|
||||||
/***** Colorized debug for thread ids *****/
|
const gchar * gst_debug_level_get_name (GstDebugLevel level);
|
||||||
#ifdef GST_DEBUG_COLOR
|
|
||||||
#define GST_DEBUG_THREAD_FORMAT "\033[00;%dm%d\033[00m"
|
|
||||||
#define GST_DEBUG_THREAD_ARGS(id) ( ((id) < 0) ? 37 : ((id) % 6 + 31) ), (id)
|
|
||||||
#else
|
|
||||||
#define GST_DEBUG_THREAD_FORMAT "%d"
|
|
||||||
#define GST_DEBUG_THREAD_ARGS(id) (id)
|
|
||||||
#endif
|
|
||||||
|
|
||||||
|
void gst_debug_add_log_function (GstLogFunction func,
|
||||||
|
gpointer data);
|
||||||
|
guint gst_debug_remove_log_function (GstLogFunction func);
|
||||||
|
guint gst_debug_remove_log_function_by_data (gpointer data);
|
||||||
|
|
||||||
|
void gst_debug_set_active (gboolean active);
|
||||||
|
gboolean gst_debug_is_active (void);
|
||||||
|
|
||||||
/**********************************************************************
|
void gst_debug_set_colored (gboolean colored);
|
||||||
* The following is a DEBUG_ENTER implementation that will wrap the
|
gboolean gst_debug_is_colored (void);
|
||||||
* function it sits at the head of. It removes the need for a
|
|
||||||
* DEBUG_LEAVE call. However, it segfaults whenever it gets anywhere
|
void gst_debug_set_default_threshold (GstDebugLevel level);
|
||||||
* near cothreads. We will not use it for the moment.
|
GstDebugLevel gst_debug_get_default_threshold (void);
|
||||||
|
void gst_debug_set_threshold_for_name (const gchar * name,
|
||||||
|
GstDebugLevel level);
|
||||||
|
void gst_debug_unset_threshold_for_name (const gchar * name);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* GST_DEBUG_CATEGORY:
|
||||||
|
* @cat: the category
|
||||||
*
|
*
|
||||||
typedef void (*_debug_function_f)();
|
* Defines a GstCategory variable.
|
||||||
G_GNUC_UNUSED static gchar *_debug_string_pointer = NULL;
|
* This macro expands to nothing if debugging is disabled.
|
||||||
G_GNUC_UNUSED static GModule *_debug_self_module = NULL;
|
*/
|
||||||
|
#define GST_DEBUG_CATEGORY(cat) GstDebugCategory *cat = NULL
|
||||||
|
/**
|
||||||
|
* GST_DEBUG_CATEGORY_EXTERN:
|
||||||
|
* @cat: the category
|
||||||
|
*
|
||||||
|
* Defines an extern GstCategory variable. Use in header files.
|
||||||
|
* This macro expands to nothing if debugging is disabled.
|
||||||
|
*/
|
||||||
|
#define GST_DEBUG_CATEGORY_EXTERN(cat) extern GstDebugCategory *cat
|
||||||
|
/**
|
||||||
|
* GST_DEBUG_CATEGORY_STATIC:
|
||||||
|
* @cat: the category
|
||||||
|
*
|
||||||
|
* Defines a static GstCategory variable.
|
||||||
|
* This macro expands to nothing if debugging is disabled.
|
||||||
|
*/
|
||||||
|
#define GST_DEBUG_CATEGORY_STATIC(cat) static GstDebugCategory *cat = NULL
|
||||||
|
/* do not use this function, use the macros below */
|
||||||
|
GstDebugCategory *_gst_debug_category_new (gchar * name,
|
||||||
|
guint color,
|
||||||
|
gchar * description);
|
||||||
|
/**
|
||||||
|
* GST_DEBUG_CATEGORY_INIT:
|
||||||
|
* @cat: the category to initialize
|
||||||
|
* @name: the name of the category
|
||||||
|
* @color: the colors to use for a color representation or 0 for no color
|
||||||
|
* @description: optional description of the category
|
||||||
|
*
|
||||||
|
* Creates a new #GstDebugCategory cat with the given properties and sets it to
|
||||||
|
* the default threshold.
|
||||||
|
* This macro expands to nothing if debugging is disabled.
|
||||||
|
* <note>
|
||||||
|
* <para>
|
||||||
|
* When naming your category, please follow the following definitions to ensure
|
||||||
|
* that the pattern matching for categories works as expected. It is not
|
||||||
|
* earth-shattering if you don't follow these conventions, but it would be nice
|
||||||
|
* for everyone.
|
||||||
|
* </para>
|
||||||
|
* <para>
|
||||||
|
* If you define a category for a plugin or a feature of it, name the category
|
||||||
|
* like the feature. So if you wanted to write a "filesrc" element, you would
|
||||||
|
* name the category "filesink". Use lowercase letters only.
|
||||||
|
* If you define more than one category for the same element, append an
|
||||||
|
* underscore and an identifier to your categories, like this: "filesrc_cache"
|
||||||
|
* </para>
|
||||||
|
* <para>
|
||||||
|
* If you create a library or an application using debugging categories, use a
|
||||||
|
* common prefix followed by an underscore for all your categories. GStreamer
|
||||||
|
* uses the GST prefix so GStreamer categories look like "GST_STATES". Be sure
|
||||||
|
* to include uppercase letters.
|
||||||
|
* </para>
|
||||||
|
* </note>
|
||||||
|
*/
|
||||||
|
#define GST_DEBUG_CATEGORY_INIT(cat,name,color,description) G_STMT_START{ \
|
||||||
|
if (cat == NULL) \
|
||||||
|
cat = _gst_debug_category_new (name,color,description); \
|
||||||
|
}G_STMT_END
|
||||||
|
void gst_debug_category_free (GstDebugCategory * category);
|
||||||
|
void gst_debug_category_set_threshold (GstDebugCategory * category,
|
||||||
|
GstDebugLevel level);
|
||||||
|
void gst_debug_category_reset_threshold (GstDebugCategory * category);
|
||||||
|
GstDebugLevel gst_debug_category_get_threshold (GstDebugCategory * category);
|
||||||
|
const gchar * gst_debug_category_get_name (GstDebugCategory * category);
|
||||||
|
guint gst_debug_category_get_color (GstDebugCategory * category);
|
||||||
|
const gchar * gst_debug_category_get_description (GstDebugCategory * category);
|
||||||
|
GSList * gst_debug_get_all_categories (void);
|
||||||
|
|
||||||
|
gchar * gst_debug_construct_term_color (guint colorinfo);
|
||||||
|
|
||||||
|
|
||||||
|
extern GstDebugCategory * GST_CAT_DEFAULT;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* GST_CAT_LEVEL_LOG:
|
||||||
|
* @cat: category to use
|
||||||
|
* @level: the severity of the message
|
||||||
|
* @object: the #GObject the message belongs to or NULL if none
|
||||||
|
* @...: A printf-style message to output
|
||||||
|
*
|
||||||
|
* Outputs a debugging message. This is the most general macro for outputting
|
||||||
|
* debugging messages. You will probably want to use one of the ones described
|
||||||
|
* below.
|
||||||
|
*/
|
||||||
#ifdef G_HAVE_ISO_VARARGS
|
#ifdef G_HAVE_ISO_VARARGS
|
||||||
|
#define GST_CAT_LEVEL_LOG(cat,level,object,...) G_STMT_START{ \
|
||||||
#define _DEBUG_ENTER_BUILTIN(...) \
|
if (gst_debug_is_active ()) { \
|
||||||
static int _debug_in_wrapper = 0; \
|
gst_debug_log (cat, level, __FILE__, GST_FUNCTION, __LINE__, G_OBJECT (object), __VA_ARGS__); \
|
||||||
gchar *_debug_string = ({ \
|
|
||||||
if (!_debug_in_wrapper) { \
|
|
||||||
void *_return_value; \
|
|
||||||
gchar *_debug_string; \
|
|
||||||
_debug_function_f function; \
|
|
||||||
void *_function_args = __builtin_apply_args(); \
|
|
||||||
_debug_in_wrapper = 1; \
|
|
||||||
_debug_string = g_strdup_printf(GST_DEBUG_PREFIX("")); \
|
|
||||||
_debug_string_pointer = _debug_string; \
|
|
||||||
fprintf(stderr,"%s: entered " FUNCTION, _debug_string); \
|
|
||||||
fprintf(stderr, __VA_ARGS__ ); \
|
|
||||||
fprintf(stderr,"\n"); \
|
|
||||||
if (_debug_self_module == NULL) _debug_self_module = g_module_open(NULL,0); \
|
|
||||||
g_module_symbol(_debug_self_module,FUNCTION,(gpointer *)&function); \
|
|
||||||
_return_value = __builtin_apply(function,_function_args,64); \
|
|
||||||
fprintf(stderr,"%s: left " FUNCTION, _debug_string); \
|
|
||||||
fprintf(stderr, __VA_ARGS__); \
|
|
||||||
fprintf(stderr,"\n"); \
|
|
||||||
g_free(_debug_string); \
|
|
||||||
__builtin_return(_return_value); \
|
|
||||||
} else { \
|
|
||||||
_debug_in_wrapper = 0; \
|
|
||||||
} \
|
} \
|
||||||
_debug_string_pointer; \
|
}G_STMT_END
|
||||||
});
|
#else /* G_HAVE_GNUC_VARARGS */
|
||||||
|
#define GST_CAT_LEVEL_LOG(cat,level,object,args...) G_STMT_START{ \
|
||||||
#elif defined(G_HAVE_GNUC_VARARGS)
|
if (gst_debug_is_active ()) { \
|
||||||
|
gst_debug_log (cat, level, __FILE__, GST_FUNCTION, __LINE__, G_OBJECT (object), ##args ); \
|
||||||
#define _DEBUG_ENTER_BUILTIN(format,args...) \
|
|
||||||
static int _debug_in_wrapper = 0; \
|
|
||||||
gchar *_debug_string = ({ \
|
|
||||||
if (!_debug_in_wrapper) { \
|
|
||||||
void *_return_value; \
|
|
||||||
gchar *_debug_string; \
|
|
||||||
_debug_function_f function; \
|
|
||||||
void *_function_args = __builtin_apply_args(); \
|
|
||||||
_debug_in_wrapper = 1; \
|
|
||||||
_debug_string = g_strdup_printf(GST_DEBUG_PREFIX("")); \
|
|
||||||
_debug_string_pointer = _debug_string; \
|
|
||||||
fprintf(stderr,"%s: entered " FUNCTION format "\n" , _debug_string , ## args ); \
|
|
||||||
if (_debug_self_module == NULL) _debug_self_module = g_module_open(NULL,0); \
|
|
||||||
g_module_symbol(_debug_self_module,FUNCTION,(gpointer *)&function); \
|
|
||||||
_return_value = __builtin_apply(function,_function_args,64); \
|
|
||||||
fprintf(stderr,"%s: left " FUNCTION format "\n" , _debug_string , ## args ); \
|
|
||||||
g_free(_debug_string); \
|
|
||||||
__builtin_return(_return_value); \
|
|
||||||
} else { \
|
|
||||||
_debug_in_wrapper = 0; \
|
|
||||||
} \
|
} \
|
||||||
_debug_string_pointer; \
|
}G_STMT_END
|
||||||
});
|
#endif /* G_HAVE_ISO_VARARGS */
|
||||||
|
|
||||||
#endif
|
#ifndef GST_DEBUG_ENABLE_DEPRECATED
|
||||||
|
|
||||||
* WARNING: there's a gcc CPP bug lurking in here. The extra space before the ##args *
|
|
||||||
* somehow make the preprocessor leave the _debug_string. If it's removed, the *
|
|
||||||
* _debug_string somehow gets stripped along with the ##args, and that's all she wrote. *
|
|
||||||
|
|
||||||
#ifdef G_HAVE_ISO_VARARGS
|
#ifdef G_HAVE_ISO_VARARGS
|
||||||
|
|
||||||
#define _DEBUG_BUILTIN(...) \
|
#define GST_CAT_ERROR_OBJECT(cat,obj,...) GST_CAT_LEVEL_LOG (cat, GST_LEVEL_ERROR, obj, __VA_ARGS__)
|
||||||
if (_debug_string != (void *)-1) { \
|
#define GST_CAT_WARNING_OBJECT(cat,obj,...) GST_CAT_LEVEL_LOG (cat, GST_LEVEL_WARNING, obj, __VA_ARGS__)
|
||||||
if (_debug_string) { \
|
#define GST_CAT_INFO_OBJECT(cat,obj,...) GST_CAT_LEVEL_LOG (cat, GST_LEVEL_INFO, obj, __VA_ARGS__)
|
||||||
fprintf(stderr, "%s: " _debug_string); \
|
#define GST_CAT_DEBUG_OBJECT(cat,obj,...) GST_CAT_LEVEL_LOG (cat, GST_LEVEL_DEBUG, obj, __VA_ARGS__)
|
||||||
fprintf(stderr, __VA_ARGS__); \
|
#define GST_CAT_LOG_OBJECT(cat,obj,...) GST_CAT_LEVEL_LOG (cat, GST_LEVEL_LOG, obj, __VA_ARGS__)
|
||||||
} else { \
|
|
||||||
fprintf(stderr,GST_DEBUG_PREFIX(": " __VA_ARGS__)); \
|
|
||||||
} \
|
|
||||||
}
|
|
||||||
|
|
||||||
#elif defined(G_HAVE_GNUC_VARARGS)
|
#define GST_CAT_ERROR(cat,...) GST_CAT_LEVEL_LOG (cat, GST_LEVEL_ERROR, NULL, __VA_ARGS__)
|
||||||
|
#define GST_CAT_WARNING(cat,...) GST_CAT_LEVEL_LOG (cat, GST_LEVEL_WARNING, NULL, __VA_ARGS__)
|
||||||
|
#define GST_CAT_INFO(cat,...) GST_CAT_LEVEL_LOG (cat, GST_LEVEL_INFO, NULL, __VA_ARGS__)
|
||||||
|
#define GST_CAT_DEBUG(cat,...) GST_CAT_LEVEL_LOG (cat, GST_LEVEL_DEBUG, NULL, __VA_ARGS__)
|
||||||
|
#define GST_CAT_LOG(cat,...) GST_CAT_LEVEL_LOG (cat, GST_LEVEL_LOG, NULL, __VA_ARGS__)
|
||||||
|
|
||||||
#define _DEBUG_BUILTIN(format,args...) \
|
#define GST_ERROR_OBJECT(obj,...) GST_CAT_LEVEL_LOG (GST_CAT_DEFAULT, GST_LEVEL_ERROR, obj, __VA_ARGS__)
|
||||||
if (_debug_string != (void *)-1) { \
|
#define GST_WARNING_OBJECT(obj,...) GST_CAT_LEVEL_LOG (GST_CAT_DEFAULT, GST_LEVEL_WARNING, obj, __VA_ARGS__)
|
||||||
if (_debug_string) \
|
#define GST_INFO_OBJECT(obj,...) GST_CAT_LEVEL_LOG (GST_CAT_DEFAULT, GST_LEVEL_INFO, obj, __VA_ARGS__)
|
||||||
fprintf(stderr,"%s: " format , _debug_string , ## args); \
|
#define GST_DEBUG_OBJECT(obj,...) GST_CAT_LEVEL_LOG (GST_CAT_DEFAULT, GST_LEVEL_DEBUG, obj, __VA_ARGS__)
|
||||||
else \
|
#define GST_LOG_OBJECT(obj,...) GST_CAT_LEVEL_LOG (GST_CAT_DEFAULT, GST_LEVEL_LOG, obj, __VA_ARGS__)
|
||||||
fprintf(stderr,GST_DEBUG_PREFIX(": " format , ## args)); \
|
|
||||||
}
|
|
||||||
|
|
||||||
#endif
|
#define GST_ERROR(...) GST_CAT_LEVEL_LOG (GST_CAT_DEFAULT, GST_LEVEL_ERROR, NULL, __VA_ARGS__)
|
||||||
|
#define GST_WARNING(...) GST_CAT_LEVEL_LOG (GST_CAT_DEFAULT, GST_LEVEL_WARNING, NULL, __VA_ARGS__)
|
||||||
|
#define GST_INFO(...) GST_CAT_LEVEL_LOG (GST_CAT_DEFAULT, GST_LEVEL_INFO, NULL, __VA_ARGS__)
|
||||||
|
#define GST_DEBUG(...) GST_CAT_LEVEL_LOG (GST_CAT_DEFAULT, GST_LEVEL_DEBUG, NULL, __VA_ARGS__)
|
||||||
|
#define GST_LOG(...) GST_CAT_LEVEL_LOG (GST_CAT_DEFAULT, GST_LEVEL_LOG, NULL, __VA_ARGS__)
|
||||||
|
|
||||||
*/
|
#else /* G_HAVE_GNUC_VARARGS */
|
||||||
|
|
||||||
|
#define GST_CAT_ERROR_OBJECT(cat,obj,args...) GST_CAT_LEVEL_LOG (cat, GST_LEVEL_ERROR, obj, ##args )
|
||||||
|
#define GST_CAT_WARNING_OBJECT(cat,obj,args...) GST_CAT_LEVEL_LOG (cat, GST_LEVEL_WARNING, obj, ##args )
|
||||||
|
#define GST_CAT_INFO_OBJECT(cat,obj,args...) GST_CAT_LEVEL_LOG (cat, GST_LEVEL_INFO, obj, ##args )
|
||||||
|
#define GST_CAT_DEBUG_OBJECT(cat,obj,args...) GST_CAT_LEVEL_LOG (cat, GST_LEVEL_DEBUG, obj, ##args )
|
||||||
|
#define GST_CAT_LOG_OBJECT(cat,obj,args...) GST_CAT_LEVEL_LOG (cat, GST_LEVEL_LOG, obj, ##args )
|
||||||
|
|
||||||
|
#define GST_CAT_ERROR(cat,args...) GST_CAT_LEVEL_LOG (cat, GST_LEVEL_ERROR, NULL, ##args )
|
||||||
|
#define GST_CAT_WARNING(cat,args...) GST_CAT_LEVEL_LOG (cat, GST_LEVEL_WARNING, NULL, ##args )
|
||||||
|
#define GST_CAT_INFO(cat,args...) GST_CAT_LEVEL_LOG (cat, GST_LEVEL_INFO, NULL, ##args )
|
||||||
|
#define GST_CAT_DEBUG(cat,args...) GST_CAT_LEVEL_LOG (cat, GST_LEVEL_DEBUG, NULL, ##args )
|
||||||
|
#define GST_CAT_LOG(cat,args...) GST_CAT_LEVEL_LOG (cat, GST_LEVEL_LOG, NULL, ##args )
|
||||||
|
|
||||||
/**********************************************************************
|
#define GST_ERROR_OBJECT(obj,args...) GST_CAT_LEVEL_LOG (GST_CAT_DEFAULT, GST_LEVEL_ERROR, obj, ##args )
|
||||||
* INFO system
|
#define GST_WARNING_OBJECT(obj,args...) GST_CAT_LEVEL_LOG (GST_CAT_DEFAULT, GST_LEVEL_WARNING, obj, ##args )
|
||||||
**********************************************************************/
|
#define GST_INFO_OBJECT(obj,args...) GST_CAT_LEVEL_LOG (GST_CAT_DEFAULT, GST_LEVEL_INFO, obj, ##args )
|
||||||
|
#define GST_DEBUG_OBJECT(obj,args...) GST_CAT_LEVEL_LOG (GST_CAT_DEFAULT, GST_LEVEL_DEBUG, obj, ##args )
|
||||||
|
#define GST_LOG_OBJECT(obj,args...) GST_CAT_LEVEL_LOG (GST_CAT_DEFAULT, GST_LEVEL_LOG, obj, ##args )
|
||||||
|
|
||||||
typedef void (*GstInfoHandler) (gint category,gboolean incore,
|
#define GST_ERROR(args...) GST_CAT_LEVEL_LOG (GST_CAT_DEFAULT, GST_LEVEL_ERROR, NULL, ##args )
|
||||||
const gchar *file,const gchar *function,
|
#define GST_WARNING(args...) GST_CAT_LEVEL_LOG (GST_CAT_DEFAULT, GST_LEVEL_WARNING, NULL, ##args )
|
||||||
gint line,const gchar *debug_string,
|
#define GST_INFO(args...) GST_CAT_LEVEL_LOG (GST_CAT_DEFAULT, GST_LEVEL_INFO, NULL, ##args )
|
||||||
void *element,gchar *string);
|
#define GST_DEBUG(args...) GST_CAT_LEVEL_LOG (GST_CAT_DEFAULT, GST_LEVEL_DEBUG, NULL, ##args )
|
||||||
|
#define GST_LOG(args...) GST_CAT_LEVEL_LOG (GST_CAT_DEFAULT, GST_LEVEL_LOG, NULL, ##args )
|
||||||
|
|
||||||
void gst_default_info_handler (gint category,gboolean incore,
|
#endif /* G_HAVE_ISO_VARARGS */
|
||||||
const gchar *file,const gchar *function,
|
|
||||||
gint line,const gchar *debug_string,
|
|
||||||
void *element,gchar *string);
|
|
||||||
|
|
||||||
extern GstInfoHandler _gst_info_handler;
|
#else /* GST_DEBUG_ENABLE_DEPRECATED */
|
||||||
extern guint32 _gst_info_categories;
|
/* This is a workaround so the old debugging stuff of Gstreamer 0.6 works.
|
||||||
|
This is undocumented and will go when 0.8 comes out. */
|
||||||
/* for include files that make too much noise normally */
|
|
||||||
#ifdef GST_INFO_FORCE_DISABLE
|
|
||||||
#undef GST_INFO_ENABLED
|
|
||||||
#endif
|
|
||||||
/* for applications that really really want all the noise */
|
|
||||||
#ifdef GST_INFO_FORCE_ENABLE
|
|
||||||
#define GST_INFO_ENABLED
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#ifdef G_HAVE_ISO_VARARGS
|
#ifdef G_HAVE_ISO_VARARGS
|
||||||
|
# define GST_INFO(cat,...) GST_CAT_LEVEL_LOG (GST_CAT_DEFAULT, GST_LEVEL_INFO, NULL, __VA_ARGS__)
|
||||||
|
# define GST_DEBUG(cat,...) GST_CAT_LEVEL_LOG (GST_CAT_DEFAULT, GST_LEVEL_DEBUG, NULL, __VA_ARGS__)
|
||||||
|
# define GST_INFO_ELEMENT(cat,obj,...) GST_CAT_LEVEL_LOG (GST_CAT_DEFAULT, GST_LEVEL_INFO, obj, __VA_ARGS__)
|
||||||
|
# define GST_DEBUG_ELEMENT(cat,obj,...) GST_CAT_LEVEL_LOG (GST_CAT_DEFAULT, GST_LEVEL_DEBUG, obj, __VA_ARGS__)
|
||||||
|
# define GST_DEBUG_ENTER(...) GST_DEBUG ("entering: " __VA_ARGS__ )
|
||||||
|
# define GST_DEBUG_LEAVE(...) GST_DEBUG ("leaving: " __VA_ARGS__ )
|
||||||
|
# define GST_INFO_ENTER(...) GST_INFO ("entering: " __VA_ARGS__ )
|
||||||
|
# define GST_INFO_LEAVE(...) GST_INFO ("leaving: " __VA_ARGS__ )
|
||||||
|
#else /* G_HAVE_GNUC_VARARGS */
|
||||||
|
# define GST_INFO(cat,args...) GST_CAT_LEVEL_LOG (GST_CAT_DEFAULT, GST_LEVEL_INFO, NULL, ##args )
|
||||||
|
# define GST_DEBUG(cat,args...) GST_CAT_LEVEL_LOG (GST_CAT_DEFAULT, GST_LEVEL_DEBUG, NULL, ##args )
|
||||||
|
# define GST_INFO_ELEMENT(cat,obj,args...) GST_CAT_LEVEL_LOG (GST_CAT_DEFAULT, GST_LEVEL_INFO, obj, ##args )
|
||||||
|
# define GST_DEBUG_ELEMENT(cat,obj,args...) GST_CAT_LEVEL_LOG (GST_CAT_DEFAULT, GST_LEVEL_DEBUG, obj, ##args )
|
||||||
|
# define GST_DEBUG_ENTER(args...) GST_DEBUG ("entering: " ##args )
|
||||||
|
# define GST_DEBUG_LEAVE(args...) GST_DEBUG ("leaving: " ##args )
|
||||||
|
# define GST_INFO_ENTER(args...) GST_INFO ("entering: " ##args )
|
||||||
|
# define GST_INFO_LEAVE(args...) GST_INFO ("leaving: " ##args )
|
||||||
|
#endif /* G_HAVE_ISO_VARARGS */
|
||||||
|
|
||||||
#ifdef GST_INFO_ENABLED
|
#endif /* !GST_DEBUG_ENABLE_DEPRECATED */
|
||||||
#define GST_INFO(cat,...) G_STMT_START{ \
|
|
||||||
if ((1<<cat) & _gst_info_categories) \
|
|
||||||
_gst_info_handler(cat,_GST_DEBUG_INCORE,__FILE__,FUNCTION,__LINE__,_debug_string, \
|
|
||||||
NULL,g_strdup_printf( __VA_ARGS__ )); \
|
|
||||||
}G_STMT_END
|
|
||||||
|
|
||||||
#define GST_INFO_ELEMENT(cat,element,...) G_STMT_START{ \
|
|
||||||
if ((1<<cat) & _gst_info_categories) \
|
|
||||||
_gst_info_handler(cat,_GST_DEBUG_INCORE,__FILE__,FUNCTION,__LINE__,_debug_string, \
|
|
||||||
element,g_strdup_printf( __VA_ARGS__ )); \
|
|
||||||
}G_STMT_END
|
|
||||||
|
|
||||||
#else
|
|
||||||
#define GST_INFO(cat,...)
|
|
||||||
#define GST_INFO_ELEMENT(cat,element,...)
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#elif defined(G_HAVE_GNUC_VARARGS)
|
|
||||||
|
|
||||||
#ifdef GST_INFO_ENABLED
|
|
||||||
#define GST_INFO(cat,format,args...) G_STMT_START{ \
|
|
||||||
if ((1<<cat) & _gst_info_categories) \
|
|
||||||
_gst_info_handler(cat,_GST_DEBUG_INCORE,__FILE__,FUNCTION,__LINE__,_debug_string, \
|
|
||||||
NULL,g_strdup_printf( format , ## args )); \
|
|
||||||
}G_STMT_END
|
|
||||||
|
|
||||||
#define GST_INFO_ELEMENT(cat,element,format,args...) G_STMT_START{ \
|
|
||||||
if ((1<<cat) & _gst_info_categories) \
|
|
||||||
_gst_info_handler(cat,_GST_DEBUG_INCORE,__FILE__,FUNCTION,__LINE__,_debug_string, \
|
|
||||||
element,g_strdup_printf( format , ## args )); \
|
|
||||||
}G_STMT_END
|
|
||||||
|
|
||||||
#else
|
|
||||||
#define GST_INFO(cat,format,args...)
|
|
||||||
#define GST_INFO_ELEMENT(cat,element,format,args...)
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#endif
|
|
||||||
|
|
||||||
|
|
||||||
void gst_info_set_categories (guint32 categories);
|
|
||||||
guint32 gst_info_get_categories (void);
|
|
||||||
void gst_info_enable_category (gint category);
|
|
||||||
void gst_info_disable_category (gint category);
|
|
||||||
|
|
||||||
void gst_debug_set_categories (guint32 categories);
|
|
||||||
guint32 gst_debug_get_categories (void);
|
|
||||||
void gst_debug_enable_category (gint category);
|
|
||||||
void gst_debug_disable_category (gint category);
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
/**********************************************************************
|
|
||||||
* ERROR system
|
|
||||||
**********************************************************************/
|
|
||||||
|
|
||||||
typedef void (*GstErrorHandler) (gchar *file,gchar *function,
|
|
||||||
gint line,gchar *debug_string,
|
|
||||||
void *element,void *object,gchar *string);
|
|
||||||
|
|
||||||
void gst_default_error_handler (gchar *file,gchar *function,
|
|
||||||
gint line,gchar *debug_string,
|
|
||||||
void *element,void *object,gchar *string);
|
|
||||||
|
|
||||||
extern GstErrorHandler _gst_error_handler;
|
|
||||||
|
|
||||||
#ifdef G_HAVE_ISO_VARARGS
|
|
||||||
|
|
||||||
#define GST_ERROR(element,...) \
|
|
||||||
_gst_error_handler(__FILE__,FUNCTION,__LINE__,_debug_string, \
|
|
||||||
element,NULL,g_strdup_printf( __VA_ARGS__ ))
|
|
||||||
|
|
||||||
#define GST_ERROR_OBJECT(element,object,...) \
|
|
||||||
_gst_error_handler(__FILE__,FUNCTION,__LINE__,_debug_string, \
|
|
||||||
element,object,g_strdup_printf( __VA_ARGS__ ))
|
|
||||||
|
|
||||||
#elif defined(G_HAVE_GNUC_VARARGS)
|
|
||||||
|
|
||||||
#define GST_ERROR(element,format,args...) \
|
|
||||||
_gst_error_handler(__FILE__,FUNCTION,__LINE__,_debug_string, \
|
|
||||||
element,NULL,g_strdup_printf( format , ## args ))
|
|
||||||
|
|
||||||
#define GST_ERROR_OBJECT(element,object,format,args...) \
|
|
||||||
_gst_error_handler(__FILE__,FUNCTION,__LINE__,_debug_string, \
|
|
||||||
element,object,g_strdup_printf( format , ## args ))
|
|
||||||
|
|
||||||
#endif
|
|
||||||
|
|
||||||
/********** function pointer stuff **********/
|
/********** function pointer stuff **********/
|
||||||
#if GST_DEBUG_ENABLED
|
void* _gst_debug_register_funcptr (void * ptr,
|
||||||
void* _gst_debug_register_funcptr (void *ptr, gchar *ptrname);
|
gchar * ptrname);
|
||||||
gchar* _gst_debug_nameof_funcptr (void *ptr);
|
gchar* _gst_debug_nameof_funcptr (void * ptr);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* GST_DEBUG_FUNCPTR:
|
||||||
|
* @ptr: The function to register
|
||||||
|
*
|
||||||
|
* Register a pointer to a function with its name, so it can later be used by
|
||||||
|
* GST_DEBUG_FUNCPTR_NAME().
|
||||||
|
*
|
||||||
|
* Returns: The ptr to the function.
|
||||||
|
*/
|
||||||
#define GST_DEBUG_FUNCPTR(ptr) (_gst_debug_register_funcptr((void *)(ptr), #ptr) , ptr)
|
#define GST_DEBUG_FUNCPTR(ptr) (_gst_debug_register_funcptr((void *)(ptr), #ptr) , ptr)
|
||||||
|
/**
|
||||||
|
* GST_DEBUG_FUNCPTR_NAME:
|
||||||
|
* @ptr: pointer to the function
|
||||||
|
*
|
||||||
|
* Retrieves the name of the function, if it was previously registered with
|
||||||
|
* GST_DEBUG_FUNCPTR(). If not, it returns a description of the pointer.
|
||||||
|
* <note>
|
||||||
|
* <para>
|
||||||
|
* Make sure you free the string after use.
|
||||||
|
* </para>
|
||||||
|
* </note>
|
||||||
|
*
|
||||||
|
* Returns: The name of the function
|
||||||
|
*/
|
||||||
#define GST_DEBUG_FUNCPTR_NAME(ptr) _gst_debug_nameof_funcptr((void *)ptr)
|
#define GST_DEBUG_FUNCPTR_NAME(ptr) _gst_debug_nameof_funcptr((void *)ptr)
|
||||||
#else
|
|
||||||
|
#else /* GST_DISABLE_GST_DEBUG */
|
||||||
|
|
||||||
|
#ifdef __GNUC__
|
||||||
|
# pragma GCC poison gst_debug_log
|
||||||
|
# pragma GCC poison gst_debug_logv
|
||||||
|
# pragma GCC poison gst_debug_log_default
|
||||||
|
# pragma GCC poison _gst_debug_category_new
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#define _gst_debug_init() /* NOP */
|
||||||
|
|
||||||
|
#define gst_debug_set_log_function(func,data) /* NOP */
|
||||||
|
#define gst_debug_reset_log_function(void) /* NOP */
|
||||||
|
#define gst_debug_set_default_threshold(level) /* NOP */
|
||||||
|
#define gst_debug_get_default_threshold() (GST_LEVEL_NONE)
|
||||||
|
#define gst_debug_category_set_threshold_for_name(name, level) /* NOP */
|
||||||
|
#define gst_debug_category_unset_threshold_for_name(name) /* NOP */
|
||||||
|
|
||||||
|
#define gst_debug_level_get_name(level) ("NONE")
|
||||||
|
#define gst_debug_add_log_function(func,data) (FALSE)
|
||||||
|
#define gst_debug_remove_log_function(func) (0)
|
||||||
|
#define gst_debug_remove_log_function_by_data(data) (0)
|
||||||
|
#define gst_debug_set_active(active) /* NOP */
|
||||||
|
#define gst_debug_is_active() (FALSE)
|
||||||
|
#define gst_debug_set_colored(colored) /* NOP */
|
||||||
|
#define gst_debug_is_colored() (FALSE)
|
||||||
|
#define gst_debug_set_default_threshold(level) /* NOP */
|
||||||
|
#define gst_debug_get_default_threshold() (GST_LEVEL_NONE)
|
||||||
|
#define gst_debug_set_threshold_for_name(name,level) /* NOP */
|
||||||
|
#define gst_debug_unset_threshold_for_name(name) /* NOP */
|
||||||
|
|
||||||
|
#define GST_DEBUG_CATEGORY(var) /* NOP */
|
||||||
|
#define GST_DEBUG_CATEGORY_EXTERN(var) /* NOP */
|
||||||
|
#define GST_DEBUG_CATEGORY_STATIC(var) /* NOP */
|
||||||
|
#define GST_DEBUG_CATEGORY_INIT(var,name,color,desc) /* NOP */
|
||||||
|
#define gst_debug_category_free(category) /* NOP */
|
||||||
|
#define gst_debug_category_set_threshold(category,level) /* NOP */
|
||||||
|
#define gst_debug_category_reset_threshold(category) /* NOP */
|
||||||
|
#define gst_debug_category_get_threshold(category) (GST_LEVEL_NONE)
|
||||||
|
#define gst_debug_category_get_name(cat) ("")
|
||||||
|
#define gst_debug_category_get_color(cat) (0)
|
||||||
|
#define gst_debug_category_get_description(cat) ("")
|
||||||
|
#define gst_debug_get_all_categories() (NULL)
|
||||||
|
#define gst_debug_construct_term_color(colorinfo) (g_strdup ("00"))
|
||||||
|
|
||||||
|
#ifdef G_HAVE_ISO_VARARGS
|
||||||
|
|
||||||
|
#define GST_CAT_LEVEL_LOG(cat,level,...) /* NOP */
|
||||||
|
|
||||||
|
#define GST_CAT_ERROR_OBJECT(...) /* NOP */
|
||||||
|
#define GST_CAT_WARNING_OBJECT(...) /* NOP */
|
||||||
|
#define GST_CAT_INFO_OBJECT(...) /* NOP */
|
||||||
|
#define GST_CAT_DEBUG_OBJECT(...) /* NOP */
|
||||||
|
#define GST_CAT_LOG_OBJECT(...) /* NOP */
|
||||||
|
|
||||||
|
#define GST_CAT_ERROR(...) /* NOP */
|
||||||
|
#define GST_CAT_WARNING(...) /* NOP */
|
||||||
|
#define GST_CAT_INFO(...) /* NOP */
|
||||||
|
#define GST_CAT_DEBUG(...) /* NOP */
|
||||||
|
#define GST_CAT_LOG(...) /* NOP */
|
||||||
|
|
||||||
|
#define GST_ERROR_OBJECT(...) /* NOP */
|
||||||
|
#define GST_WARNING_OBJECT(...) /* NOP */
|
||||||
|
#define GST_INFO_OBJECT(...) /* NOP */
|
||||||
|
#define GST_DEBUG_OBJECT(...) /* NOP */
|
||||||
|
#define GST_LOG_OBJECT(...) /* NOP */
|
||||||
|
|
||||||
|
#define GST_ERROR(...) /* NOP */
|
||||||
|
#define GST_WARNING(...) /* NOP */
|
||||||
|
#define GST_INFO(...) /* NOP */
|
||||||
|
#define GST_DEBUG(...) /* NOP */
|
||||||
|
#define GST_LOG(...) /* NOP */
|
||||||
|
|
||||||
|
#ifdef GST_DEBUG_ENABLE_DEPRECATED
|
||||||
|
#define GST_INFO_ELEMENT(cat,obj,...) /* NOP */
|
||||||
|
#define GST_DEBUG_ELEMENT(cat,obj,...) /* NOP */
|
||||||
|
#define GST_DEBUG_ENTER(...) /* NOP */
|
||||||
|
#define GST_DEBUG_LEAVE(...) /* NOP */
|
||||||
|
#define GST_INFO_ENTER(...) /* NOP */
|
||||||
|
#define GST_INFO_LEAVE(...) /* NOP */
|
||||||
|
#endif /* GST_DEBUG_ENABLE_DEPRECATED */
|
||||||
|
|
||||||
|
#else /* !G_HAVE_ISO_VARARGS */
|
||||||
|
|
||||||
|
#define GST_CAT_LEVEL_LOG(cat,level,args...) /* NOP */
|
||||||
|
|
||||||
|
#define GST_CAT_ERROR_OBJECT(args...) /* NOP */
|
||||||
|
#define GST_CAT_WARNING_OBJECT(args...) /* NOP */
|
||||||
|
#define GST_CAT_INFO_OBJECT(args...) /* NOP */
|
||||||
|
#define GST_CAT_DEBUG_OBJECT(args...) /* NOP */
|
||||||
|
#define GST_CAT_LOG_OBJECT(args...) /* NOP */
|
||||||
|
|
||||||
|
#define GST_CAT_ERROR(args...) /* NOP */
|
||||||
|
#define GST_CAT_WARNING(args...) /* NOP */
|
||||||
|
#define GST_CAT_INFO(args...) /* NOP */
|
||||||
|
#define GST_CAT_DEBUG(args...) /* NOP */
|
||||||
|
#define GST_CAT_LOG(args...) /* NOP */
|
||||||
|
|
||||||
|
#define GST_ERROR_OBJECT(args...) /* NOP */
|
||||||
|
#define GST_WARNING_OBJECT(args...) /* NOP */
|
||||||
|
#define GST_INFO_OBJECT(args...) /* NOP */
|
||||||
|
#define GST_DEBUG_OBJECT(args...) /* NOP */
|
||||||
|
#define GST_LOG_OBJECT(args...) /* NOP */
|
||||||
|
|
||||||
|
#define GST_ERROR(args...) /* NOP */
|
||||||
|
#define GST_WARNING(args...) /* NOP */
|
||||||
|
#define GST_INFO(args...) /* NOP */
|
||||||
|
#define GST_DEBUG(args...) /* NOP */
|
||||||
|
#define GST_LOG(args...) /* NOP */
|
||||||
|
|
||||||
|
#ifdef GST_DEBUG_ENABLE_DEPRECATED
|
||||||
|
#define GST_INFO_ELEMENT(cat,obj,args...) /* NOP */
|
||||||
|
#define GST_DEBUG_ELEMENT(cat,obj,args...) /* NOP */
|
||||||
|
#define GST_DEBUG_ENTER(args...) /* NOP */
|
||||||
|
#define GST_DEBUG_LEAVE(args...) /* NOP */
|
||||||
|
#define GST_INFO_ENTER(args...) /* NOP */
|
||||||
|
#define GST_INFO_LEAVE(args...) /* NOP */
|
||||||
|
#endif /* GST_DEBUG_ENABLE_DEPRECATED */
|
||||||
|
|
||||||
|
#endif /* G_HAVE_ISO_VARARGS */
|
||||||
|
|
||||||
#define GST_DEBUG_FUNCPTR(ptr) (ptr)
|
#define GST_DEBUG_FUNCPTR(ptr) (ptr)
|
||||||
#define GST_DEBUG_FUNCPTR_NAME(ptr) ""
|
#define GST_DEBUG_FUNCPTR_NAME(ptr) (g_strdup_printf ("%p", ptr))
|
||||||
#endif /* GST_DEBUG_ENABLED */
|
|
||||||
|
#endif /* GST_DISABLE_GST_DEBUG */
|
||||||
|
|
||||||
void gst_debug_print_stack_trace (void);
|
void gst_debug_print_stack_trace (void);
|
||||||
|
|
||||||
|
|
|
@ -23,7 +23,8 @@
|
||||||
#include "gst_private.h"
|
#include "gst_private.h"
|
||||||
|
|
||||||
#include "gstobject.h"
|
#include "gstobject.h"
|
||||||
#include "gstlog.h"
|
#include "gstinfo.h"
|
||||||
|
|
||||||
#ifndef GST_DISABLE_TRACE
|
#ifndef GST_DISABLE_TRACE
|
||||||
#include "gsttrace.h"
|
#include "gsttrace.h"
|
||||||
#endif
|
#endif
|
||||||
|
@ -211,8 +212,7 @@ gst_object_ref (GstObject *object)
|
||||||
{
|
{
|
||||||
g_return_val_if_fail (GST_IS_OBJECT (object), NULL);
|
g_return_val_if_fail (GST_IS_OBJECT (object), NULL);
|
||||||
|
|
||||||
GST_DEBUG (GST_CAT_REFCOUNTING, "ref %p '%s' %d->%d", object,
|
GST_CAT_LOG_OBJECT (GST_CAT_REFCOUNTING, object, "ref %d->%d",
|
||||||
GST_STR_NULL (GST_OBJECT_NAME (object)),
|
|
||||||
G_OBJECT (object)->ref_count,
|
G_OBJECT (object)->ref_count,
|
||||||
G_OBJECT (object)->ref_count + 1);
|
G_OBJECT (object)->ref_count + 1);
|
||||||
|
|
||||||
|
@ -233,8 +233,7 @@ gst_object_unref (GstObject *object)
|
||||||
g_return_if_fail (GST_IS_OBJECT (object));
|
g_return_if_fail (GST_IS_OBJECT (object));
|
||||||
g_return_if_fail (G_OBJECT (object)->ref_count > 0);
|
g_return_if_fail (G_OBJECT (object)->ref_count > 0);
|
||||||
|
|
||||||
GST_DEBUG (GST_CAT_REFCOUNTING, "unref %p '%s' %d->%d", object,
|
GST_CAT_LOG_OBJECT (GST_CAT_REFCOUNTING, object, "unref %d->%d",
|
||||||
GST_STR_NULL (GST_OBJECT_NAME (object)),
|
|
||||||
G_OBJECT (object)->ref_count,
|
G_OBJECT (object)->ref_count,
|
||||||
G_OBJECT (object)->ref_count - 1);
|
G_OBJECT (object)->ref_count - 1);
|
||||||
|
|
||||||
|
@ -256,7 +255,7 @@ gst_object_sink (GstObject *object)
|
||||||
g_return_if_fail (object != NULL);
|
g_return_if_fail (object != NULL);
|
||||||
g_return_if_fail (GST_IS_OBJECT (object));
|
g_return_if_fail (GST_IS_OBJECT (object));
|
||||||
|
|
||||||
GST_DEBUG (GST_CAT_REFCOUNTING, "sink %p '%s'", object, GST_STR_NULL (GST_OBJECT_NAME (object)));
|
GST_CAT_LOG_OBJECT (GST_CAT_REFCOUNTING, object, "sink");
|
||||||
|
|
||||||
if (GST_OBJECT_FLOATING (object)) {
|
if (GST_OBJECT_FLOATING (object)) {
|
||||||
GST_FLAG_UNSET (object, GST_FLOATING);
|
GST_FLAG_UNSET (object, GST_FLOATING);
|
||||||
|
@ -275,7 +274,13 @@ gst_object_sink (GstObject *object)
|
||||||
void
|
void
|
||||||
gst_object_replace (GstObject **oldobj, GstObject *newobj)
|
gst_object_replace (GstObject **oldobj, GstObject *newobj)
|
||||||
{
|
{
|
||||||
GST_DEBUG (GST_CAT_REFCOUNTING, "replace %p %p", *oldobj, newobj);
|
g_return_if_fail (oldobj != NULL);
|
||||||
|
g_return_if_fail (*oldobj == NULL || GST_IS_OBJECT (*oldobj));
|
||||||
|
g_return_if_fail (newobj == NULL || GST_IS_OBJECT (newobj));
|
||||||
|
|
||||||
|
GST_CAT_LOG (GST_CAT_REFCOUNTING, "replace %s %s",
|
||||||
|
*oldobj ? GST_STR_NULL (GST_OBJECT_NAME (*oldobj)) : "(NONE)",
|
||||||
|
newobj ? GST_STR_NULL (GST_OBJECT_NAME (newobj)) : "(NONE)");
|
||||||
|
|
||||||
if (*oldobj != newobj) {
|
if (*oldobj != newobj) {
|
||||||
if (newobj) gst_object_ref (newobj);
|
if (newobj) gst_object_ref (newobj);
|
||||||
|
@ -288,7 +293,7 @@ gst_object_replace (GstObject **oldobj, GstObject *newobj)
|
||||||
static void
|
static void
|
||||||
gst_object_dispose (GObject *object)
|
gst_object_dispose (GObject *object)
|
||||||
{
|
{
|
||||||
GST_DEBUG (GST_CAT_REFCOUNTING, "dispose %p '%s'", object, GST_STR_NULL (GST_OBJECT_NAME (object)));
|
GST_CAT_LOG_OBJECT (GST_CAT_REFCOUNTING, object, "dispose");
|
||||||
|
|
||||||
GST_FLAG_SET (GST_OBJECT (object), GST_DESTROYED);
|
GST_FLAG_SET (GST_OBJECT (object), GST_DESTROYED);
|
||||||
GST_OBJECT_PARENT (object) = NULL;
|
GST_OBJECT_PARENT (object) = NULL;
|
||||||
|
@ -302,7 +307,7 @@ gst_object_finalize (GObject *object)
|
||||||
{
|
{
|
||||||
GstObject *gstobject = GST_OBJECT (object);
|
GstObject *gstobject = GST_OBJECT (object);
|
||||||
|
|
||||||
GST_DEBUG (GST_CAT_REFCOUNTING, "finalize %p '%s'", object, GST_STR_NULL (GST_OBJECT_NAME (object)));
|
GST_CAT_LOG_OBJECT (GST_CAT_REFCOUNTING, object, "finalize");
|
||||||
|
|
||||||
g_signal_handlers_destroy (object);
|
g_signal_handlers_destroy (object);
|
||||||
|
|
||||||
|
@ -346,7 +351,7 @@ gst_object_dispatch_properties_changed (GObject *object,
|
||||||
while (gst_object) {
|
while (gst_object) {
|
||||||
/* need own category? */
|
/* need own category? */
|
||||||
for (i = 0; i < n_pspecs; i++) {
|
for (i = 0; i < n_pspecs; i++) {
|
||||||
GST_DEBUG (GST_CAT_EVENT, "deep notification from %s to %s (%s)", GST_OBJECT_NAME (object),
|
GST_CAT_LOG (GST_CAT_EVENT, "deep notification from %s to %s (%s)", GST_OBJECT_NAME (object),
|
||||||
GST_OBJECT_NAME (gst_object), pspecs[i]->name);
|
GST_OBJECT_NAME (gst_object), pspecs[i]->name);
|
||||||
g_signal_emit (gst_object, gst_object_signals[DEEP_NOTIFY], g_quark_from_string (pspecs[i]->name),
|
g_signal_emit (gst_object, gst_object_signals[DEEP_NOTIFY], g_quark_from_string (pspecs[i]->name),
|
||||||
(GstObject *) object, pspecs[i]);
|
(GstObject *) object, pspecs[i]);
|
||||||
|
@ -501,11 +506,7 @@ gst_object_set_parent (GstObject *object, GstObject *parent)
|
||||||
g_return_if_fail (parent != NULL);
|
g_return_if_fail (parent != NULL);
|
||||||
g_return_if_fail (GST_IS_OBJECT (parent));
|
g_return_if_fail (GST_IS_OBJECT (parent));
|
||||||
g_return_if_fail (object != parent);
|
g_return_if_fail (object != parent);
|
||||||
|
g_return_if_fail (object->parent == NULL);
|
||||||
if (object->parent != NULL) {
|
|
||||||
GST_ERROR_OBJECT (object,object->parent, "object's parent is already set, must unparent first");
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
gst_object_ref (object);
|
gst_object_ref (object);
|
||||||
gst_object_sink (object);
|
gst_object_sink (object);
|
||||||
|
@ -545,7 +546,7 @@ gst_object_unparent (GstObject *object)
|
||||||
if (object->parent == NULL)
|
if (object->parent == NULL)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
GST_DEBUG (GST_CAT_REFCOUNTING, "unparent '%s'",GST_OBJECT_NAME(object));
|
GST_CAT_LOG_OBJECT (GST_CAT_REFCOUNTING, object, "unparent");
|
||||||
|
|
||||||
g_signal_emit (G_OBJECT (object), gst_object_signals[PARENT_UNSET], 0, object->parent);
|
g_signal_emit (G_OBJECT (object), gst_object_signals[PARENT_UNSET], 0, object->parent);
|
||||||
|
|
||||||
|
|
167
gst/gstpad.c
167
gst/gstpad.c
|
@ -20,7 +20,6 @@
|
||||||
* Boston, MA 02111-1307, USA.
|
* Boston, MA 02111-1307, USA.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
/* #define GST_DEBUG_ENABLED */
|
|
||||||
#include "gst_private.h"
|
#include "gst_private.h"
|
||||||
|
|
||||||
#include "gstpad.h"
|
#include "gstpad.h"
|
||||||
|
@ -30,7 +29,7 @@
|
||||||
#include "gstbin.h"
|
#include "gstbin.h"
|
||||||
#include "gstscheduler.h"
|
#include "gstscheduler.h"
|
||||||
#include "gstevent.h"
|
#include "gstevent.h"
|
||||||
#include "gstlog.h"
|
#include "gstinfo.h"
|
||||||
|
|
||||||
enum {
|
enum {
|
||||||
TEMPL_PAD_CREATED,
|
TEMPL_PAD_CREATED,
|
||||||
|
@ -398,11 +397,11 @@ gst_pad_set_active (GstPad *pad, gboolean active)
|
||||||
realpad = GST_PAD_REALIZE (pad);
|
realpad = GST_PAD_REALIZE (pad);
|
||||||
|
|
||||||
if (active) {
|
if (active) {
|
||||||
GST_DEBUG (GST_CAT_PADS, "activating pad %s:%s",
|
GST_CAT_DEBUG (GST_CAT_PADS, "activating pad %s:%s",
|
||||||
GST_DEBUG_PAD_NAME (realpad));
|
GST_DEBUG_PAD_NAME (realpad));
|
||||||
GST_FLAG_UNSET (realpad, GST_PAD_DISABLED);
|
GST_FLAG_UNSET (realpad, GST_PAD_DISABLED);
|
||||||
} else {
|
} else {
|
||||||
GST_DEBUG (GST_CAT_PADS, "de-activating pad %s:%s",
|
GST_CAT_DEBUG (GST_CAT_PADS, "de-activating pad %s:%s",
|
||||||
GST_DEBUG_PAD_NAME (realpad));
|
GST_DEBUG_PAD_NAME (realpad));
|
||||||
GST_FLAG_SET (realpad, GST_PAD_DISABLED);
|
GST_FLAG_SET (realpad, GST_PAD_DISABLED);
|
||||||
}
|
}
|
||||||
|
@ -474,7 +473,7 @@ gst_pad_set_chain_function (GstPad *pad, GstPadChainFunction chain)
|
||||||
g_return_if_fail (GST_IS_REAL_PAD (pad));
|
g_return_if_fail (GST_IS_REAL_PAD (pad));
|
||||||
|
|
||||||
GST_RPAD_CHAINFUNC (pad) = chain;
|
GST_RPAD_CHAINFUNC (pad) = chain;
|
||||||
GST_DEBUG (GST_CAT_PADS, "chainfunc for %s:%s set to %s",
|
GST_CAT_DEBUG (GST_CAT_PADS, "chainfunc for %s:%s set to %s",
|
||||||
GST_DEBUG_PAD_NAME (pad), GST_DEBUG_FUNCPTR_NAME (chain));
|
GST_DEBUG_PAD_NAME (pad), GST_DEBUG_FUNCPTR_NAME (chain));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -494,7 +493,7 @@ gst_pad_set_get_function (GstPad *pad,
|
||||||
|
|
||||||
GST_RPAD_GETFUNC (pad) = get;
|
GST_RPAD_GETFUNC (pad) = get;
|
||||||
|
|
||||||
GST_DEBUG (GST_CAT_PADS, "getfunc for %s:%s set to %s",
|
GST_CAT_DEBUG (GST_CAT_PADS, "getfunc for %s:%s set to %s",
|
||||||
GST_DEBUG_PAD_NAME (pad), GST_DEBUG_FUNCPTR_NAME (get));
|
GST_DEBUG_PAD_NAME (pad), GST_DEBUG_FUNCPTR_NAME (get));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -513,7 +512,7 @@ gst_pad_set_event_function (GstPad *pad,
|
||||||
|
|
||||||
GST_RPAD_EVENTFUNC (pad) = event;
|
GST_RPAD_EVENTFUNC (pad) = event;
|
||||||
|
|
||||||
GST_DEBUG (GST_CAT_PADS, "eventfunc for %s:%s set to %s",
|
GST_CAT_DEBUG (GST_CAT_PADS, "eventfunc for %s:%s set to %s",
|
||||||
GST_DEBUG_PAD_NAME (pad), GST_DEBUG_FUNCPTR_NAME (event));
|
GST_DEBUG_PAD_NAME (pad), GST_DEBUG_FUNCPTR_NAME (event));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -532,7 +531,7 @@ gst_pad_set_event_mask_function (GstPad *pad,
|
||||||
|
|
||||||
GST_RPAD_EVENTMASKFUNC (pad) = mask_func;
|
GST_RPAD_EVENTMASKFUNC (pad) = mask_func;
|
||||||
|
|
||||||
GST_DEBUG (GST_CAT_PADS, "eventmaskfunc for %s:%s set to %s",
|
GST_CAT_DEBUG (GST_CAT_PADS, "eventmaskfunc for %s:%s set to %s",
|
||||||
GST_DEBUG_PAD_NAME (pad), GST_DEBUG_FUNCPTR_NAME (mask_func));
|
GST_DEBUG_PAD_NAME (pad), GST_DEBUG_FUNCPTR_NAME (mask_func));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -607,7 +606,7 @@ gst_pad_set_convert_function (GstPad *pad,
|
||||||
|
|
||||||
GST_RPAD_CONVERTFUNC (pad) = convert;
|
GST_RPAD_CONVERTFUNC (pad) = convert;
|
||||||
|
|
||||||
GST_DEBUG (GST_CAT_PADS, "convertfunc for %s:%s set to %s",
|
GST_CAT_DEBUG (GST_CAT_PADS, "convertfunc for %s:%s set to %s",
|
||||||
GST_DEBUG_PAD_NAME (pad), GST_DEBUG_FUNCPTR_NAME (convert));
|
GST_DEBUG_PAD_NAME (pad), GST_DEBUG_FUNCPTR_NAME (convert));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -626,7 +625,7 @@ gst_pad_set_query_function (GstPad *pad, GstPadQueryFunction query)
|
||||||
|
|
||||||
GST_RPAD_QUERYFUNC (pad) = query;
|
GST_RPAD_QUERYFUNC (pad) = query;
|
||||||
|
|
||||||
GST_DEBUG (GST_CAT_PADS, "queryfunc for %s:%s set to %s",
|
GST_CAT_DEBUG (GST_CAT_PADS, "queryfunc for %s:%s set to %s",
|
||||||
GST_DEBUG_PAD_NAME (pad), GST_DEBUG_FUNCPTR_NAME (query));
|
GST_DEBUG_PAD_NAME (pad), GST_DEBUG_FUNCPTR_NAME (query));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -645,7 +644,7 @@ gst_pad_set_query_type_function (GstPad *pad, GstPadQueryTypeFunction type_func)
|
||||||
|
|
||||||
GST_RPAD_QUERYTYPEFUNC (pad) = type_func;
|
GST_RPAD_QUERYTYPEFUNC (pad) = type_func;
|
||||||
|
|
||||||
GST_DEBUG (GST_CAT_PADS, "querytypefunc for %s:%s set to %s",
|
GST_CAT_DEBUG (GST_CAT_PADS, "querytypefunc for %s:%s set to %s",
|
||||||
GST_DEBUG_PAD_NAME (pad), GST_DEBUG_FUNCPTR_NAME (type_func));
|
GST_DEBUG_PAD_NAME (pad), GST_DEBUG_FUNCPTR_NAME (type_func));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -719,7 +718,7 @@ gst_pad_set_internal_link_function (GstPad *pad,
|
||||||
g_return_if_fail (GST_IS_REAL_PAD (pad));
|
g_return_if_fail (GST_IS_REAL_PAD (pad));
|
||||||
|
|
||||||
GST_RPAD_INTLINKFUNC (pad) = intlink;
|
GST_RPAD_INTLINKFUNC (pad) = intlink;
|
||||||
GST_DEBUG (GST_CAT_PADS, "internal link for %s:%s set to %s",
|
GST_CAT_DEBUG (GST_CAT_PADS, "internal link for %s:%s set to %s",
|
||||||
GST_DEBUG_PAD_NAME (pad), GST_DEBUG_FUNCPTR_NAME (intlink));
|
GST_DEBUG_PAD_NAME (pad), GST_DEBUG_FUNCPTR_NAME (intlink));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -737,7 +736,7 @@ gst_pad_set_formats_function (GstPad *pad, GstPadFormatsFunction formats)
|
||||||
g_return_if_fail (GST_IS_REAL_PAD (pad));
|
g_return_if_fail (GST_IS_REAL_PAD (pad));
|
||||||
|
|
||||||
GST_RPAD_FORMATSFUNC (pad) = formats;
|
GST_RPAD_FORMATSFUNC (pad) = formats;
|
||||||
GST_DEBUG (GST_CAT_PADS, "formats function for %s:%s set to %s",
|
GST_CAT_DEBUG (GST_CAT_PADS, "formats function for %s:%s set to %s",
|
||||||
GST_DEBUG_PAD_NAME (pad), GST_DEBUG_FUNCPTR_NAME (formats));
|
GST_DEBUG_PAD_NAME (pad), GST_DEBUG_FUNCPTR_NAME (formats));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -757,7 +756,7 @@ gst_pad_set_link_function (GstPad *pad,
|
||||||
g_return_if_fail (GST_IS_REAL_PAD (pad));
|
g_return_if_fail (GST_IS_REAL_PAD (pad));
|
||||||
|
|
||||||
GST_RPAD_LINKFUNC (pad) = link;
|
GST_RPAD_LINKFUNC (pad) = link;
|
||||||
GST_DEBUG (GST_CAT_PADS, "linkfunc for %s:%s set to %s",
|
GST_CAT_DEBUG (GST_CAT_PADS, "linkfunc for %s:%s set to %s",
|
||||||
GST_DEBUG_PAD_NAME (pad), GST_DEBUG_FUNCPTR_NAME (link));
|
GST_DEBUG_PAD_NAME (pad), GST_DEBUG_FUNCPTR_NAME (link));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -776,7 +775,7 @@ gst_pad_set_getcaps_function (GstPad *pad,
|
||||||
g_return_if_fail (GST_IS_REAL_PAD (pad));
|
g_return_if_fail (GST_IS_REAL_PAD (pad));
|
||||||
|
|
||||||
GST_RPAD_GETCAPSFUNC (pad) = getcaps;
|
GST_RPAD_GETCAPSFUNC (pad) = getcaps;
|
||||||
GST_DEBUG (GST_CAT_PADS, "getcapsfunc for %s:%s set to %s",
|
GST_CAT_DEBUG (GST_CAT_PADS, "getcapsfunc for %s:%s set to %s",
|
||||||
GST_DEBUG_PAD_NAME (pad), GST_DEBUG_FUNCPTR_NAME (getcaps));
|
GST_DEBUG_PAD_NAME (pad), GST_DEBUG_FUNCPTR_NAME (getcaps));
|
||||||
}
|
}
|
||||||
/**
|
/**
|
||||||
|
@ -796,7 +795,7 @@ gst_pad_set_bufferpool_function (GstPad *pad,
|
||||||
g_return_if_fail (GST_PAD_IS_SINK (pad));
|
g_return_if_fail (GST_PAD_IS_SINK (pad));
|
||||||
|
|
||||||
GST_RPAD_BUFFERPOOLFUNC (pad) = bufpool;
|
GST_RPAD_BUFFERPOOLFUNC (pad) = bufpool;
|
||||||
GST_DEBUG (GST_CAT_PADS, "bufferpoolfunc for %s:%s set to %s",
|
GST_CAT_DEBUG (GST_CAT_PADS, "bufferpoolfunc for %s:%s set to %s",
|
||||||
GST_DEBUG_PAD_NAME (pad), GST_DEBUG_FUNCPTR_NAME (bufpool));
|
GST_DEBUG_PAD_NAME (pad), GST_DEBUG_FUNCPTR_NAME (bufpool));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -820,7 +819,7 @@ gst_pad_unlink (GstPad *srcpad,
|
||||||
g_return_if_fail (sinkpad != NULL);
|
g_return_if_fail (sinkpad != NULL);
|
||||||
g_return_if_fail (GST_IS_PAD (sinkpad));
|
g_return_if_fail (GST_IS_PAD (sinkpad));
|
||||||
|
|
||||||
GST_INFO (GST_CAT_ELEMENT_PADS, "unlinking %s:%s(%p) and %s:%s(%p)",
|
GST_CAT_INFO (GST_CAT_ELEMENT_PADS, "unlinking %s:%s(%p) and %s:%s(%p)",
|
||||||
GST_DEBUG_PAD_NAME (srcpad), srcpad,
|
GST_DEBUG_PAD_NAME (srcpad), srcpad,
|
||||||
GST_DEBUG_PAD_NAME (sinkpad), sinkpad);
|
GST_DEBUG_PAD_NAME (sinkpad), sinkpad);
|
||||||
|
|
||||||
|
@ -874,7 +873,7 @@ gst_pad_unlink (GstPad *srcpad,
|
||||||
g_signal_emit (G_OBJECT (realsink), gst_real_pad_signals[REAL_UNLINKED],
|
g_signal_emit (G_OBJECT (realsink), gst_real_pad_signals[REAL_UNLINKED],
|
||||||
0, realsrc);
|
0, realsrc);
|
||||||
|
|
||||||
GST_INFO (GST_CAT_ELEMENT_PADS, "unlinked %s:%s and %s:%s",
|
GST_CAT_INFO (GST_CAT_ELEMENT_PADS, "unlinked %s:%s and %s:%s",
|
||||||
GST_DEBUG_PAD_NAME (srcpad), GST_DEBUG_PAD_NAME (sinkpad));
|
GST_DEBUG_PAD_NAME (srcpad), GST_DEBUG_PAD_NAME (sinkpad));
|
||||||
|
|
||||||
gst_object_unref (GST_OBJECT (realsrc));
|
gst_object_unref (GST_OBJECT (realsrc));
|
||||||
|
@ -988,7 +987,7 @@ gst_pad_link_filtered (GstPad *srcpad, GstPad *sinkpad, GstCaps *filtercaps)
|
||||||
g_return_val_if_fail (sinkpad != NULL, FALSE);
|
g_return_val_if_fail (sinkpad != NULL, FALSE);
|
||||||
g_return_val_if_fail (GST_IS_PAD (sinkpad), FALSE);
|
g_return_val_if_fail (GST_IS_PAD (sinkpad), FALSE);
|
||||||
|
|
||||||
GST_INFO (GST_CAT_PADS, "trying to link %s:%s and %s:%s",
|
GST_CAT_INFO (GST_CAT_PADS, "trying to link %s:%s and %s:%s",
|
||||||
GST_DEBUG_PAD_NAME (srcpad), GST_DEBUG_PAD_NAME (sinkpad));
|
GST_DEBUG_PAD_NAME (srcpad), GST_DEBUG_PAD_NAME (sinkpad));
|
||||||
|
|
||||||
/* now we need to deal with the real/ghost stuff */
|
/* now we need to deal with the real/ghost stuff */
|
||||||
|
@ -996,27 +995,27 @@ gst_pad_link_filtered (GstPad *srcpad, GstPad *sinkpad, GstCaps *filtercaps)
|
||||||
realsink = GST_PAD_REALIZE (sinkpad);
|
realsink = GST_PAD_REALIZE (sinkpad);
|
||||||
|
|
||||||
if ((GST_PAD (realsrc) != srcpad) || (GST_PAD (realsink) != sinkpad)) {
|
if ((GST_PAD (realsrc) != srcpad) || (GST_PAD (realsink) != sinkpad)) {
|
||||||
GST_INFO (GST_CAT_PADS, "*actually* linking %s:%s and %s:%s",
|
GST_CAT_INFO (GST_CAT_PADS, "*actually* linking %s:%s and %s:%s",
|
||||||
GST_DEBUG_PAD_NAME (realsrc), GST_DEBUG_PAD_NAME (realsink));
|
GST_DEBUG_PAD_NAME (realsrc), GST_DEBUG_PAD_NAME (realsink));
|
||||||
}
|
}
|
||||||
/* FIXME: shouldn't we convert this to g_return_val_if_fail? */
|
/* FIXME: shouldn't we convert this to g_return_val_if_fail? */
|
||||||
if (GST_RPAD_PEER (realsrc) != NULL) {
|
if (GST_RPAD_PEER (realsrc) != NULL) {
|
||||||
GST_INFO (GST_CAT_PADS, "Real source pad %s:%s has a peer, failed",
|
GST_CAT_INFO (GST_CAT_PADS, "Real source pad %s:%s has a peer, failed",
|
||||||
GST_DEBUG_PAD_NAME (realsrc));
|
GST_DEBUG_PAD_NAME (realsrc));
|
||||||
return FALSE;
|
return FALSE;
|
||||||
}
|
}
|
||||||
if (GST_RPAD_PEER (realsink) != NULL) {
|
if (GST_RPAD_PEER (realsink) != NULL) {
|
||||||
GST_INFO (GST_CAT_PADS, "Real sink pad %s:%s has a peer, failed",
|
GST_CAT_INFO (GST_CAT_PADS, "Real sink pad %s:%s has a peer, failed",
|
||||||
GST_DEBUG_PAD_NAME (realsink));
|
GST_DEBUG_PAD_NAME (realsink));
|
||||||
return FALSE;
|
return FALSE;
|
||||||
}
|
}
|
||||||
if (GST_PAD_PARENT (realsrc) == NULL) {
|
if (GST_PAD_PARENT (realsrc) == NULL) {
|
||||||
GST_INFO (GST_CAT_PADS, "Real src pad %s:%s has no parent, failed",
|
GST_CAT_INFO (GST_CAT_PADS, "Real src pad %s:%s has no parent, failed",
|
||||||
GST_DEBUG_PAD_NAME (realsrc));
|
GST_DEBUG_PAD_NAME (realsrc));
|
||||||
return FALSE;
|
return FALSE;
|
||||||
}
|
}
|
||||||
if (GST_PAD_PARENT (realsink) == NULL) {
|
if (GST_PAD_PARENT (realsink) == NULL) {
|
||||||
GST_INFO (GST_CAT_PADS, "Real sink pad %s:%s has no parent, failed",
|
GST_CAT_INFO (GST_CAT_PADS, "Real sink pad %s:%s has no parent, failed",
|
||||||
GST_DEBUG_PAD_NAME (realsrc));
|
GST_DEBUG_PAD_NAME (realsrc));
|
||||||
return FALSE;
|
return FALSE;
|
||||||
}
|
}
|
||||||
|
@ -1037,12 +1036,12 @@ gst_pad_link_filtered (GstPad *srcpad, GstPad *sinkpad, GstCaps *filtercaps)
|
||||||
realsink = temppad;
|
realsink = temppad;
|
||||||
}
|
}
|
||||||
if (GST_RPAD_DIRECTION (realsrc) != GST_PAD_SRC) {
|
if (GST_RPAD_DIRECTION (realsrc) != GST_PAD_SRC) {
|
||||||
GST_INFO (GST_CAT_PADS, "Real src pad %s:%s is not a source pad, failed",
|
GST_CAT_INFO (GST_CAT_PADS, "Real src pad %s:%s is not a source pad, failed",
|
||||||
GST_DEBUG_PAD_NAME (realsrc));
|
GST_DEBUG_PAD_NAME (realsrc));
|
||||||
return FALSE;
|
return FALSE;
|
||||||
}
|
}
|
||||||
if (GST_RPAD_DIRECTION (realsink) != GST_PAD_SINK) {
|
if (GST_RPAD_DIRECTION (realsink) != GST_PAD_SINK) {
|
||||||
GST_INFO (GST_CAT_PADS, "Real sink pad %s:%s is not a sink pad, failed",
|
GST_CAT_INFO (GST_CAT_PADS, "Real sink pad %s:%s is not a sink pad, failed",
|
||||||
GST_DEBUG_PAD_NAME (realsink));
|
GST_DEBUG_PAD_NAME (realsink));
|
||||||
return FALSE;
|
return FALSE;
|
||||||
}
|
}
|
||||||
|
@ -1053,7 +1052,7 @@ gst_pad_link_filtered (GstPad *srcpad, GstPad *sinkpad, GstCaps *filtercaps)
|
||||||
/* try to negotiate the pads, we don't need to clear the caps here */
|
/* try to negotiate the pads, we don't need to clear the caps here */
|
||||||
if (!gst_pad_try_relink_filtered_func (realsrc, realsink,
|
if (!gst_pad_try_relink_filtered_func (realsrc, realsink,
|
||||||
filtercaps, FALSE)) {
|
filtercaps, FALSE)) {
|
||||||
GST_DEBUG (GST_CAT_CAPS, "relink_filtered_func failed, can't link");
|
GST_CAT_DEBUG (GST_CAT_CAPS, "relink_filtered_func failed, can't link");
|
||||||
|
|
||||||
GST_RPAD_PEER (realsrc) = NULL;
|
GST_RPAD_PEER (realsrc) = NULL;
|
||||||
GST_RPAD_PEER (realsink) = NULL;
|
GST_RPAD_PEER (realsink) = NULL;
|
||||||
|
@ -1077,12 +1076,12 @@ gst_pad_link_filtered (GstPad *srcpad, GstPad *sinkpad, GstCaps *filtercaps)
|
||||||
GST_PAD_CAST (realsrc), GST_PAD_CAST (realsink));
|
GST_PAD_CAST (realsrc), GST_PAD_CAST (realsink));
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
GST_INFO (GST_CAT_PADS, "not telling link to scheduler %s:%s and %s:%s, %p %p",
|
GST_CAT_INFO (GST_CAT_PADS, "not telling link to scheduler %s:%s and %s:%s, %p %p",
|
||||||
GST_DEBUG_PAD_NAME (srcpad), GST_DEBUG_PAD_NAME (sinkpad),
|
GST_DEBUG_PAD_NAME (srcpad), GST_DEBUG_PAD_NAME (sinkpad),
|
||||||
src_sched, sink_sched);
|
src_sched, sink_sched);
|
||||||
}
|
}
|
||||||
|
|
||||||
GST_INFO (GST_CAT_PADS, "linked %s:%s and %s:%s, successful",
|
GST_CAT_INFO (GST_CAT_PADS, "linked %s:%s and %s:%s, successful",
|
||||||
GST_DEBUG_PAD_NAME (srcpad), GST_DEBUG_PAD_NAME (sinkpad));
|
GST_DEBUG_PAD_NAME (srcpad), GST_DEBUG_PAD_NAME (sinkpad));
|
||||||
|
|
||||||
return TRUE;
|
return TRUE;
|
||||||
|
@ -1305,12 +1304,12 @@ gst_pad_try_set_caps_func (GstRealPad *pad, GstCaps *caps, gboolean notify)
|
||||||
* negotiation */
|
* negotiation */
|
||||||
if (parent && GST_STATE (parent) < GST_STATE_READY)
|
if (parent && GST_STATE (parent) < GST_STATE_READY)
|
||||||
{
|
{
|
||||||
GST_DEBUG (GST_CAT_CAPS, "parent %s of pad %s:%s is not READY",
|
GST_CAT_DEBUG (GST_CAT_CAPS, "parent %s of pad %s:%s is not READY",
|
||||||
GST_ELEMENT_NAME (parent), GST_DEBUG_PAD_NAME (pad));
|
GST_ELEMENT_NAME (parent), GST_DEBUG_PAD_NAME (pad));
|
||||||
return GST_PAD_LINK_DELAYED;
|
return GST_PAD_LINK_DELAYED;
|
||||||
}
|
}
|
||||||
|
|
||||||
GST_INFO (GST_CAT_CAPS, "trying to set caps %p on pad %s:%s",
|
GST_CAT_INFO (GST_CAT_CAPS, "trying to set caps %p on pad %s:%s",
|
||||||
caps, GST_DEBUG_PAD_NAME (pad));
|
caps, GST_DEBUG_PAD_NAME (pad));
|
||||||
|
|
||||||
/* first see if we have to check against a filter, we ref the caps here as we're
|
/* first see if we have to check against a filter, we ref the caps here as we're
|
||||||
|
@ -1331,7 +1330,7 @@ gst_pad_try_set_caps_func (GstRealPad *pad, GstCaps *caps, gboolean notify)
|
||||||
|
|
||||||
/* oops, empty intersection, caps don"t have anything in common */
|
/* oops, empty intersection, caps don"t have anything in common */
|
||||||
if (!intersection) {
|
if (!intersection) {
|
||||||
GST_INFO (GST_CAT_CAPS, "caps did not intersect with %s:%s's allowed caps",
|
GST_CAT_INFO (GST_CAT_CAPS, "caps did not intersect with %s:%s's allowed caps",
|
||||||
GST_DEBUG_PAD_NAME (pad));
|
GST_DEBUG_PAD_NAME (pad));
|
||||||
gst_caps_debug (caps, "caps themselves (attemped to set)");
|
gst_caps_debug (caps, "caps themselves (attemped to set)");
|
||||||
gst_caps_debug (allowed,
|
gst_caps_debug (allowed,
|
||||||
|
@ -1352,7 +1351,7 @@ gst_pad_try_set_caps_func (GstRealPad *pad, GstCaps *caps, gboolean notify)
|
||||||
gchar *debug_string;
|
gchar *debug_string;
|
||||||
gboolean negotiating;
|
gboolean negotiating;
|
||||||
|
|
||||||
GST_INFO (GST_CAT_CAPS, "calling link function on pad %s:%s",
|
GST_CAT_INFO (GST_CAT_CAPS, "calling link function on pad %s:%s",
|
||||||
GST_DEBUG_PAD_NAME (pad));
|
GST_DEBUG_PAD_NAME (pad));
|
||||||
|
|
||||||
negotiating = GST_FLAG_IS_SET (pad, GST_PAD_NEGOTIATING);
|
negotiating = GST_FLAG_IS_SET (pad, GST_PAD_NEGOTIATING);
|
||||||
|
@ -1387,18 +1386,18 @@ gst_pad_try_set_caps_func (GstRealPad *pad, GstCaps *caps, gboolean notify)
|
||||||
return GST_PAD_LINK_REFUSED;
|
return GST_PAD_LINK_REFUSED;
|
||||||
}
|
}
|
||||||
|
|
||||||
GST_INFO (GST_CAT_CAPS,
|
GST_CAT_INFO (GST_CAT_CAPS,
|
||||||
"got reply %s (%d) from link function on pad %s:%s",
|
"got reply %s (%d) from link function on pad %s:%s",
|
||||||
debug_string, res, GST_DEBUG_PAD_NAME (pad));
|
debug_string, res, GST_DEBUG_PAD_NAME (pad));
|
||||||
|
|
||||||
/* done means the link function called another caps negotiate function
|
/* done means the link function called another caps negotiate function
|
||||||
* on this pad that succeeded, we dont need to continue */
|
* on this pad that succeeded, we dont need to continue */
|
||||||
if (res == GST_PAD_LINK_DONE) {
|
if (res == GST_PAD_LINK_DONE) {
|
||||||
GST_INFO (GST_CAT_CAPS, "pad %s:%s is done", GST_DEBUG_PAD_NAME (pad));
|
GST_CAT_INFO (GST_CAT_CAPS, "pad %s:%s is done", GST_DEBUG_PAD_NAME (pad));
|
||||||
return GST_PAD_LINK_DONE;
|
return GST_PAD_LINK_DONE;
|
||||||
}
|
}
|
||||||
if (res == GST_PAD_LINK_REFUSED) {
|
if (res == GST_PAD_LINK_REFUSED) {
|
||||||
GST_INFO (GST_CAT_CAPS, "pad %s:%s doesn't accept caps",
|
GST_CAT_INFO (GST_CAT_CAPS, "pad %s:%s doesn't accept caps",
|
||||||
GST_DEBUG_PAD_NAME (pad));
|
GST_DEBUG_PAD_NAME (pad));
|
||||||
return GST_PAD_LINK_REFUSED;
|
return GST_PAD_LINK_REFUSED;
|
||||||
}
|
}
|
||||||
|
@ -1406,7 +1405,7 @@ gst_pad_try_set_caps_func (GstRealPad *pad, GstCaps *caps, gboolean notify)
|
||||||
/* we can only set caps on the pad if they are fixed */
|
/* we can only set caps on the pad if they are fixed */
|
||||||
if (GST_CAPS_IS_FIXED (caps)) {
|
if (GST_CAPS_IS_FIXED (caps)) {
|
||||||
|
|
||||||
GST_INFO (GST_CAT_CAPS, "setting caps on pad %s:%s",
|
GST_CAT_INFO (GST_CAT_CAPS, "setting caps on pad %s:%s",
|
||||||
GST_DEBUG_PAD_NAME (pad));
|
GST_DEBUG_PAD_NAME (pad));
|
||||||
/* if we got this far all is ok, remove the old caps, set the new one */
|
/* if we got this far all is ok, remove the old caps, set the new one */
|
||||||
gst_caps_replace_sink (&GST_PAD_CAPS (pad), caps);
|
gst_caps_replace_sink (&GST_PAD_CAPS (pad), caps);
|
||||||
|
@ -1414,7 +1413,7 @@ gst_pad_try_set_caps_func (GstRealPad *pad, GstCaps *caps, gboolean notify)
|
||||||
g_object_notify (G_OBJECT (pad), "caps");
|
g_object_notify (G_OBJECT (pad), "caps");
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
GST_INFO (GST_CAT_CAPS,
|
GST_CAT_INFO (GST_CAT_CAPS,
|
||||||
"caps are not fixed on pad %s:%s, not setting them yet",
|
"caps are not fixed on pad %s:%s, not setting them yet",
|
||||||
GST_DEBUG_PAD_NAME (pad));
|
GST_DEBUG_PAD_NAME (pad));
|
||||||
|
|
||||||
|
@ -1443,7 +1442,7 @@ gst_pad_try_set_caps (GstPad *pad, GstCaps *caps)
|
||||||
realpad = GST_PAD_REALIZE (pad);
|
realpad = GST_PAD_REALIZE (pad);
|
||||||
peer = GST_RPAD_PEER (realpad);
|
peer = GST_RPAD_PEER (realpad);
|
||||||
|
|
||||||
GST_INFO (GST_CAT_CAPS, "trying to set caps %p on pad %s:%s",
|
GST_CAT_INFO (GST_CAT_CAPS, "trying to set caps %p on pad %s:%s",
|
||||||
caps, GST_DEBUG_PAD_NAME (realpad));
|
caps, GST_DEBUG_PAD_NAME (realpad));
|
||||||
|
|
||||||
gst_caps_debug (caps, "caps that we are trying to set");
|
gst_caps_debug (caps, "caps that we are trying to set");
|
||||||
|
@ -1454,7 +1453,7 @@ gst_pad_try_set_caps (GstPad *pad, GstCaps *caps)
|
||||||
|
|
||||||
/* setting non fixed caps on a pad is not allowed */
|
/* setting non fixed caps on a pad is not allowed */
|
||||||
if (!GST_CAPS_IS_FIXED (caps)) {
|
if (!GST_CAPS_IS_FIXED (caps)) {
|
||||||
GST_INFO (GST_CAT_CAPS,
|
GST_CAT_INFO (GST_CAT_CAPS,
|
||||||
"trying to set unfixed caps on pad %s:%s, not allowed",
|
"trying to set unfixed caps on pad %s:%s, not allowed",
|
||||||
GST_DEBUG_PAD_NAME (realpad));
|
GST_DEBUG_PAD_NAME (realpad));
|
||||||
g_warning ("trying to set non fixed caps on pad %s:%s, not allowed",
|
g_warning ("trying to set non fixed caps on pad %s:%s, not allowed",
|
||||||
|
@ -1469,7 +1468,7 @@ gst_pad_try_set_caps (GstPad *pad, GstCaps *caps)
|
||||||
* if it has a link function */
|
* if it has a link function */
|
||||||
if (peer && ((set_retval = gst_pad_try_set_caps_func (peer, caps, TRUE)) <= 0))
|
if (peer && ((set_retval = gst_pad_try_set_caps_func (peer, caps, TRUE)) <= 0))
|
||||||
{
|
{
|
||||||
GST_INFO (GST_CAT_CAPS, "tried to set caps on peerpad %s:%s but couldn't, return value %d",
|
GST_CAT_INFO (GST_CAT_CAPS, "tried to set caps on peerpad %s:%s but couldn't, return value %d",
|
||||||
GST_DEBUG_PAD_NAME (peer), set_retval);
|
GST_DEBUG_PAD_NAME (peer), set_retval);
|
||||||
goto done;
|
goto done;
|
||||||
}
|
}
|
||||||
|
@ -1477,11 +1476,11 @@ gst_pad_try_set_caps (GstPad *pad, GstCaps *caps)
|
||||||
/* then try to set our own caps, we don't need to be notified */
|
/* then try to set our own caps, we don't need to be notified */
|
||||||
if ((set_retval = gst_pad_try_set_caps_func (realpad, caps, FALSE)) <= 0)
|
if ((set_retval = gst_pad_try_set_caps_func (realpad, caps, FALSE)) <= 0)
|
||||||
{
|
{
|
||||||
GST_INFO (GST_CAT_CAPS, "tried to set own caps on pad %s:%s but couldn't, return value %d",
|
GST_CAT_INFO (GST_CAT_CAPS, "tried to set own caps on pad %s:%s but couldn't, return value %d",
|
||||||
GST_DEBUG_PAD_NAME (realpad), set_retval);
|
GST_DEBUG_PAD_NAME (realpad), set_retval);
|
||||||
goto done;
|
goto done;
|
||||||
}
|
}
|
||||||
GST_INFO (GST_CAT_CAPS, "succeeded setting caps %p on pad %s:%s, return value %d",
|
GST_CAT_INFO (GST_CAT_CAPS, "succeeded setting caps %p on pad %s:%s, return value %d",
|
||||||
caps, GST_DEBUG_PAD_NAME (realpad), set_retval);
|
caps, GST_DEBUG_PAD_NAME (realpad), set_retval);
|
||||||
g_assert (GST_PAD_CAPS (pad));
|
g_assert (GST_PAD_CAPS (pad));
|
||||||
|
|
||||||
|
@ -1517,7 +1516,7 @@ gst_pad_try_relink_filtered_func (GstRealPad *srcpad, GstRealPad *sinkpad,
|
||||||
|
|
||||||
/* optinally clear the caps */
|
/* optinally clear the caps */
|
||||||
if (clear) {
|
if (clear) {
|
||||||
GST_INFO (GST_CAT_PADS,
|
GST_CAT_INFO (GST_CAT_PADS,
|
||||||
"start relink filtered %s:%s and %s:%s, clearing caps",
|
"start relink filtered %s:%s and %s:%s, clearing caps",
|
||||||
GST_DEBUG_PAD_NAME (realsrc), GST_DEBUG_PAD_NAME (realsink));
|
GST_DEBUG_PAD_NAME (realsrc), GST_DEBUG_PAD_NAME (realsink));
|
||||||
|
|
||||||
|
@ -1527,16 +1526,16 @@ gst_pad_try_relink_filtered_func (GstRealPad *srcpad, GstRealPad *sinkpad,
|
||||||
gst_caps_replace (&GST_RPAD_FILTER (realsink), NULL);
|
gst_caps_replace (&GST_RPAD_FILTER (realsink), NULL);
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
GST_INFO (GST_CAT_PADS, "start relink filtered %s:%s and %s:%s",
|
GST_CAT_INFO (GST_CAT_PADS, "start relink filtered %s:%s and %s:%s",
|
||||||
GST_DEBUG_PAD_NAME (realsrc), GST_DEBUG_PAD_NAME (realsink));
|
GST_DEBUG_PAD_NAME (realsrc), GST_DEBUG_PAD_NAME (realsink));
|
||||||
}
|
}
|
||||||
|
|
||||||
srccaps = gst_pad_get_caps (GST_PAD (realsrc));
|
srccaps = gst_pad_get_caps (GST_PAD (realsrc));
|
||||||
GST_DEBUG (GST_CAT_PADS, "dumping caps of pad %s:%s",
|
GST_CAT_DEBUG (GST_CAT_PADS, "dumping caps of pad %s:%s",
|
||||||
GST_DEBUG_PAD_NAME (realsrc));
|
GST_DEBUG_PAD_NAME (realsrc));
|
||||||
gst_caps_debug (srccaps, "caps of src pad (pre-relink)");
|
gst_caps_debug (srccaps, "caps of src pad (pre-relink)");
|
||||||
sinkcaps = gst_pad_get_caps (GST_PAD (realsink));
|
sinkcaps = gst_pad_get_caps (GST_PAD (realsink));
|
||||||
GST_DEBUG (GST_CAT_PADS, "dumping caps of pad %s:%s",
|
GST_CAT_DEBUG (GST_CAT_PADS, "dumping caps of pad %s:%s",
|
||||||
GST_DEBUG_PAD_NAME (realsink));
|
GST_DEBUG_PAD_NAME (realsink));
|
||||||
gst_caps_debug (sinkcaps, "caps of sink pad (pre-relink)");
|
gst_caps_debug (sinkcaps, "caps of sink pad (pre-relink)");
|
||||||
|
|
||||||
|
@ -1548,14 +1547,14 @@ gst_pad_try_relink_filtered_func (GstRealPad *srcpad, GstRealPad *sinkpad,
|
||||||
if (!intersection && (srccaps || sinkcaps)) {
|
if (!intersection && (srccaps || sinkcaps)) {
|
||||||
/* the intersection is NULL but the pad caps were not both NULL,
|
/* the intersection is NULL but the pad caps were not both NULL,
|
||||||
* this means they have no common format */
|
* this means they have no common format */
|
||||||
GST_INFO (GST_CAT_PADS, "pads %s:%s and %s:%s have no common type",
|
GST_CAT_INFO (GST_CAT_PADS, "pads %s:%s and %s:%s have no common type",
|
||||||
GST_DEBUG_PAD_NAME (realsrc), GST_DEBUG_PAD_NAME (realsink));
|
GST_DEBUG_PAD_NAME (realsrc), GST_DEBUG_PAD_NAME (realsink));
|
||||||
/* make sure any floating caps from gst_pad_get_caps are freed here */
|
/* make sure any floating caps from gst_pad_get_caps are freed here */
|
||||||
gst_caps_sink (srccaps);
|
gst_caps_sink (srccaps);
|
||||||
gst_caps_sink (sinkcaps);
|
gst_caps_sink (sinkcaps);
|
||||||
return FALSE;
|
return FALSE;
|
||||||
} else {
|
} else {
|
||||||
GST_INFO (GST_CAT_PADS, "pads %s:%s and %s:%s intersected to %s caps",
|
GST_CAT_INFO (GST_CAT_PADS, "pads %s:%s and %s:%s intersected to %s caps",
|
||||||
GST_DEBUG_PAD_NAME (realsrc), GST_DEBUG_PAD_NAME (realsink),
|
GST_DEBUG_PAD_NAME (realsrc), GST_DEBUG_PAD_NAME (realsink),
|
||||||
(intersection ?
|
(intersection ?
|
||||||
(GST_CAPS_IS_FIXED (intersection) ? "fixed" : "variable") :
|
(GST_CAPS_IS_FIXED (intersection) ? "fixed" : "variable") :
|
||||||
|
@ -1575,7 +1574,7 @@ gst_pad_try_relink_filtered_func (GstRealPad *srcpad, GstRealPad *sinkpad,
|
||||||
gst_caps_sink (intersection);
|
gst_caps_sink (intersection);
|
||||||
|
|
||||||
if (!filtered_intersection) {
|
if (!filtered_intersection) {
|
||||||
GST_INFO (GST_CAT_PADS,
|
GST_CAT_INFO (GST_CAT_PADS,
|
||||||
"filtered link between pads %s:%s and %s:%s is empty",
|
"filtered link between pads %s:%s and %s:%s is empty",
|
||||||
GST_DEBUG_PAD_NAME (realsrc), GST_DEBUG_PAD_NAME (realsink));
|
GST_DEBUG_PAD_NAME (realsrc), GST_DEBUG_PAD_NAME (realsink));
|
||||||
return FALSE;
|
return FALSE;
|
||||||
|
@ -1587,7 +1586,7 @@ gst_pad_try_relink_filtered_func (GstRealPad *srcpad, GstRealPad *sinkpad,
|
||||||
gst_caps_replace_sink (&GST_RPAD_APPFILTER (realsrc), filtercaps);
|
gst_caps_replace_sink (&GST_RPAD_APPFILTER (realsrc), filtercaps);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
GST_DEBUG (GST_CAT_CAPS, "setting filter for link to:");
|
GST_CAT_DEBUG (GST_CAT_CAPS, "setting filter for link to:");
|
||||||
gst_caps_debug (intersection, "filter for link");
|
gst_caps_debug (intersection, "filter for link");
|
||||||
|
|
||||||
/* both the app filter and the filter, while stored on both peer pads,
|
/* both the app filter and the filter, while stored on both peer pads,
|
||||||
|
@ -1630,35 +1629,35 @@ gst_pad_perform_negotiate (GstPad *srcpad, GstPad *sinkpad)
|
||||||
/* shortcut negotiation */
|
/* shortcut negotiation */
|
||||||
parent = GST_PAD_PARENT (realsrc);
|
parent = GST_PAD_PARENT (realsrc);
|
||||||
if (parent && GST_STATE (parent) < GST_STATE_READY) {
|
if (parent && GST_STATE (parent) < GST_STATE_READY) {
|
||||||
GST_DEBUG (GST_CAT_CAPS, "parent %s of pad %s:%s is not READY",
|
GST_CAT_DEBUG (GST_CAT_CAPS, "parent %s of pad %s:%s is not READY",
|
||||||
GST_ELEMENT_NAME (parent), GST_DEBUG_PAD_NAME (realsrc));
|
GST_ELEMENT_NAME (parent), GST_DEBUG_PAD_NAME (realsrc));
|
||||||
return TRUE;
|
return TRUE;
|
||||||
}
|
}
|
||||||
parent = GST_PAD_PARENT (realsink);
|
parent = GST_PAD_PARENT (realsink);
|
||||||
if (parent && GST_STATE (parent) < GST_STATE_READY) {
|
if (parent && GST_STATE (parent) < GST_STATE_READY) {
|
||||||
GST_DEBUG (GST_CAT_CAPS, "parent %s of pad %s:%s is not READY",
|
GST_CAT_DEBUG (GST_CAT_CAPS, "parent %s of pad %s:%s is not READY",
|
||||||
GST_ELEMENT_NAME (parent), GST_DEBUG_PAD_NAME (realsink));
|
GST_ELEMENT_NAME (parent), GST_DEBUG_PAD_NAME (realsink));
|
||||||
return TRUE;
|
return TRUE;
|
||||||
}
|
}
|
||||||
|
|
||||||
GST_INFO (GST_CAT_PADS, "perform negotiate for link %s:%s-%s:%s",
|
GST_CAT_INFO (GST_CAT_PADS, "perform negotiate for link %s:%s-%s:%s",
|
||||||
GST_DEBUG_PAD_NAME (realsrc), GST_DEBUG_PAD_NAME (realsink));
|
GST_DEBUG_PAD_NAME (realsrc), GST_DEBUG_PAD_NAME (realsink));
|
||||||
|
|
||||||
filter = GST_RPAD_APPFILTER (realsrc);
|
filter = GST_RPAD_APPFILTER (realsrc);
|
||||||
if (filter) {
|
if (filter) {
|
||||||
GST_INFO (GST_CAT_PADS, "dumping filter for link %s:%s-%s:%s",
|
GST_CAT_INFO (GST_CAT_PADS, "dumping filter for link %s:%s-%s:%s",
|
||||||
GST_DEBUG_PAD_NAME (realsrc), GST_DEBUG_PAD_NAME (realsink));
|
GST_DEBUG_PAD_NAME (realsrc), GST_DEBUG_PAD_NAME (realsink));
|
||||||
gst_caps_debug (filter, "link filter caps");
|
gst_caps_debug (filter, "link filter caps");
|
||||||
}
|
}
|
||||||
|
|
||||||
/* calculate the new caps here */
|
/* calculate the new caps here */
|
||||||
srccaps = gst_pad_get_caps (GST_PAD (realsrc));
|
srccaps = gst_pad_get_caps (GST_PAD (realsrc));
|
||||||
GST_DEBUG (GST_CAT_PADS, "dumping caps of pad %s:%s",
|
GST_CAT_DEBUG (GST_CAT_PADS, "dumping caps of pad %s:%s",
|
||||||
GST_DEBUG_PAD_NAME (realsrc));
|
GST_DEBUG_PAD_NAME (realsrc));
|
||||||
gst_caps_debug (srccaps,
|
gst_caps_debug (srccaps,
|
||||||
"src caps, awaiting negotiation, after applying filter");
|
"src caps, awaiting negotiation, after applying filter");
|
||||||
sinkcaps = gst_pad_get_caps (GST_PAD (realsink));
|
sinkcaps = gst_pad_get_caps (GST_PAD (realsink));
|
||||||
GST_DEBUG (GST_CAT_PADS, "dumping caps of pad %s:%s",
|
GST_CAT_DEBUG (GST_CAT_PADS, "dumping caps of pad %s:%s",
|
||||||
GST_DEBUG_PAD_NAME (realsink));
|
GST_DEBUG_PAD_NAME (realsink));
|
||||||
gst_caps_debug (sinkcaps,
|
gst_caps_debug (sinkcaps,
|
||||||
"sink caps, awaiting negotiation, after applying filter");
|
"sink caps, awaiting negotiation, after applying filter");
|
||||||
|
@ -1783,7 +1782,7 @@ gst_pad_proxy_link (GstPad *pad, GstCaps *caps)
|
||||||
|
|
||||||
peer = GST_RPAD_PEER (realpad);
|
peer = GST_RPAD_PEER (realpad);
|
||||||
|
|
||||||
GST_INFO (GST_CAT_CAPS, "proxy link to pad %s:%s",
|
GST_CAT_INFO (GST_CAT_CAPS, "proxy link to pad %s:%s",
|
||||||
GST_DEBUG_PAD_NAME (realpad));
|
GST_DEBUG_PAD_NAME (realpad));
|
||||||
|
|
||||||
if (peer && gst_pad_try_set_caps_func (peer, caps, TRUE) < 0)
|
if (peer && gst_pad_try_set_caps_func (peer, caps, TRUE) < 0)
|
||||||
|
@ -1794,7 +1793,7 @@ gst_pad_proxy_link (GstPad *pad, GstCaps *caps)
|
||||||
if (peer) {
|
if (peer) {
|
||||||
gst_caps_debug (caps, "proxy link filter");
|
gst_caps_debug (caps, "proxy link filter");
|
||||||
|
|
||||||
GST_INFO (GST_CAT_CAPS, "setting filter on %s:%s and %s:%s",
|
GST_CAT_INFO (GST_CAT_CAPS, "setting filter on %s:%s and %s:%s",
|
||||||
GST_DEBUG_PAD_NAME (peer), GST_DEBUG_PAD_NAME (realpad));
|
GST_DEBUG_PAD_NAME (peer), GST_DEBUG_PAD_NAME (realpad));
|
||||||
|
|
||||||
gst_caps_replace_sink (&GST_RPAD_FILTER (peer), caps);
|
gst_caps_replace_sink (&GST_RPAD_FILTER (peer), caps);
|
||||||
|
@ -1824,26 +1823,26 @@ gst_pad_get_caps (GstPad *pad)
|
||||||
|
|
||||||
realpad = GST_PAD_REALIZE (pad);
|
realpad = GST_PAD_REALIZE (pad);
|
||||||
|
|
||||||
GST_DEBUG (GST_CAT_CAPS, "get pad caps of %s:%s (%p)",
|
GST_CAT_DEBUG (GST_CAT_CAPS, "get pad caps of %s:%s (%p)",
|
||||||
GST_DEBUG_PAD_NAME (realpad), realpad);
|
GST_DEBUG_PAD_NAME (realpad), realpad);
|
||||||
|
|
||||||
/* note that we will not _ref the caps here as this function might be
|
/* note that we will not _ref the caps here as this function might be
|
||||||
* called recursively */
|
* called recursively */
|
||||||
if (GST_PAD_CAPS (realpad)) {
|
if (GST_PAD_CAPS (realpad)) {
|
||||||
GST_DEBUG (GST_CAT_CAPS, "using pad real caps %p", GST_PAD_CAPS (realpad));
|
GST_CAT_DEBUG (GST_CAT_CAPS, "using pad real caps %p", GST_PAD_CAPS (realpad));
|
||||||
return GST_PAD_CAPS (realpad);
|
return GST_PAD_CAPS (realpad);
|
||||||
}
|
}
|
||||||
else if GST_RPAD_GETCAPSFUNC (realpad) {
|
else if GST_RPAD_GETCAPSFUNC (realpad) {
|
||||||
GST_DEBUG (GST_CAT_CAPS, "using pad get function");
|
GST_CAT_DEBUG (GST_CAT_CAPS, "using pad get function");
|
||||||
return GST_RPAD_GETCAPSFUNC (realpad) (GST_PAD_CAST (realpad), NULL);
|
return GST_RPAD_GETCAPSFUNC (realpad) (GST_PAD_CAST (realpad), NULL);
|
||||||
}
|
}
|
||||||
else if (GST_PAD_PAD_TEMPLATE (realpad)) {
|
else if (GST_PAD_PAD_TEMPLATE (realpad)) {
|
||||||
GstPadTemplate *templ = GST_PAD_PAD_TEMPLATE (realpad);
|
GstPadTemplate *templ = GST_PAD_PAD_TEMPLATE (realpad);
|
||||||
GST_DEBUG (GST_CAT_CAPS, "using pad template %p with caps %p",
|
GST_CAT_DEBUG (GST_CAT_CAPS, "using pad template %p with caps %p",
|
||||||
templ, GST_PAD_TEMPLATE_CAPS (templ));
|
templ, GST_PAD_TEMPLATE_CAPS (templ));
|
||||||
return GST_PAD_TEMPLATE_CAPS (templ);
|
return GST_PAD_TEMPLATE_CAPS (templ);
|
||||||
}
|
}
|
||||||
GST_DEBUG (GST_CAT_CAPS, "pad has no caps");
|
GST_CAT_DEBUG (GST_CAT_CAPS, "pad has no caps");
|
||||||
|
|
||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
|
@ -1921,7 +1920,7 @@ gst_pad_check_compatibility (GstPad *srcpad, GstPad *sinkpad)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
GST_DEBUG (GST_CAT_PADS,
|
GST_CAT_DEBUG (GST_CAT_PADS,
|
||||||
"could not check capabilities of pads (%s:%s) and (%s:%s) %p %p",
|
"could not check capabilities of pads (%s:%s) and (%s:%s) %p %p",
|
||||||
GST_DEBUG_PAD_NAME (srcpad), GST_DEBUG_PAD_NAME (sinkpad),
|
GST_DEBUG_PAD_NAME (srcpad), GST_DEBUG_PAD_NAME (sinkpad),
|
||||||
GST_PAD_CAPS (srcpad), GST_PAD_CAPS (sinkpad));
|
GST_PAD_CAPS (srcpad), GST_PAD_CAPS (sinkpad));
|
||||||
|
@ -1967,7 +1966,7 @@ gst_pad_get_allowed_caps (GstPad *pad)
|
||||||
|
|
||||||
realpad = GST_PAD_REALIZE (pad);
|
realpad = GST_PAD_REALIZE (pad);
|
||||||
|
|
||||||
GST_DEBUG (GST_CAT_PROPERTIES, "get allowed caps of %s:%s",
|
GST_CAT_DEBUG (GST_CAT_PROPERTIES, "get allowed caps of %s:%s",
|
||||||
GST_DEBUG_PAD_NAME (pad));
|
GST_DEBUG_PAD_NAME (pad));
|
||||||
|
|
||||||
caps = gst_caps_ref (GST_RPAD_FILTER (realpad));
|
caps = gst_caps_ref (GST_RPAD_FILTER (realpad));
|
||||||
|
@ -1993,7 +1992,7 @@ gst_pad_recalc_allowed_caps (GstPad *pad)
|
||||||
g_return_val_if_fail (pad != NULL, FALSE);
|
g_return_val_if_fail (pad != NULL, FALSE);
|
||||||
g_return_val_if_fail (GST_IS_PAD (pad), FALSE);
|
g_return_val_if_fail (GST_IS_PAD (pad), FALSE);
|
||||||
|
|
||||||
GST_DEBUG (GST_CAT_PROPERTIES, "set allowed caps of %s:%s",
|
GST_CAT_DEBUG (GST_CAT_PROPERTIES, "set allowed caps of %s:%s",
|
||||||
GST_DEBUG_PAD_NAME (pad));
|
GST_DEBUG_PAD_NAME (pad));
|
||||||
|
|
||||||
|
|
||||||
|
@ -2072,16 +2071,16 @@ gst_pad_get_bufferpool (GstPad *pad)
|
||||||
if (!peer)
|
if (!peer)
|
||||||
return NULL;
|
return NULL;
|
||||||
|
|
||||||
GST_DEBUG_ENTER ("(%s:%s)", GST_DEBUG_PAD_NAME (pad));
|
GST_CAT_DEBUG (GST_CAT_BUFFER, "(%s:%s): getting bufferpool", GST_DEBUG_PAD_NAME (pad));
|
||||||
|
|
||||||
if (peer->bufferpoolfunc) {
|
if (peer->bufferpoolfunc) {
|
||||||
GST_DEBUG (GST_CAT_PADS,
|
GST_CAT_DEBUG (GST_CAT_PADS,
|
||||||
"calling bufferpoolfunc &%s (@%p) of peer pad %s:%s",
|
"calling bufferpoolfunc &%s (@%p) of peer pad %s:%s",
|
||||||
GST_DEBUG_FUNCPTR_NAME (peer->bufferpoolfunc),
|
GST_DEBUG_FUNCPTR_NAME (peer->bufferpoolfunc),
|
||||||
&peer->bufferpoolfunc, GST_DEBUG_PAD_NAME (((GstPad*) peer)));
|
&peer->bufferpoolfunc, GST_DEBUG_PAD_NAME (((GstPad*) peer)));
|
||||||
return (peer->bufferpoolfunc) (((GstPad*) peer));
|
return (peer->bufferpoolfunc) (((GstPad*) peer));
|
||||||
} else {
|
} else {
|
||||||
GST_DEBUG (GST_CAT_PADS, "no bufferpoolfunc for peer pad %s:%s at %p",
|
GST_CAT_DEBUG (GST_CAT_PADS, "no bufferpoolfunc for peer pad %s:%s at %p",
|
||||||
GST_DEBUG_PAD_NAME (((GstPad*) peer)), &peer->bufferpoolfunc);
|
GST_DEBUG_PAD_NAME (((GstPad*) peer)), &peer->bufferpoolfunc);
|
||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
|
@ -2097,7 +2096,7 @@ gst_real_pad_dispose (GObject *object)
|
||||||
* and a parent would hold a reference */
|
* and a parent would hold a reference */
|
||||||
g_assert (GST_PAD_PEER (pad) == NULL);
|
g_assert (GST_PAD_PEER (pad) == NULL);
|
||||||
|
|
||||||
GST_DEBUG (GST_CAT_REFCOUNTING, "dispose %s:%s", GST_DEBUG_PAD_NAME(pad));
|
GST_CAT_DEBUG (GST_CAT_REFCOUNTING, "dispose %s:%s", GST_DEBUG_PAD_NAME(pad));
|
||||||
|
|
||||||
/* we destroy the ghostpads, because they are nothing without the real pad */
|
/* we destroy the ghostpads, because they are nothing without the real pad */
|
||||||
if (GST_REAL_PAD (pad)->ghostpads) {
|
if (GST_REAL_PAD (pad)->ghostpads) {
|
||||||
|
@ -2109,7 +2108,7 @@ gst_real_pad_dispose (GObject *object)
|
||||||
GstPad *ghostpad = GST_PAD (ghostpads->data);
|
GstPad *ghostpad = GST_PAD (ghostpads->data);
|
||||||
|
|
||||||
if (GST_IS_ELEMENT (GST_OBJECT_PARENT (ghostpad))){
|
if (GST_IS_ELEMENT (GST_OBJECT_PARENT (ghostpad))){
|
||||||
GST_DEBUG (GST_CAT_REFCOUNTING, "removing ghost pad from element '%s'",
|
GST_CAT_DEBUG (GST_CAT_REFCOUNTING, "removing ghost pad from element '%s'",
|
||||||
GST_OBJECT_NAME (GST_OBJECT_PARENT (ghostpad)));
|
GST_OBJECT_NAME (GST_OBJECT_PARENT (ghostpad)));
|
||||||
|
|
||||||
gst_element_remove_ghost_pad (GST_ELEMENT (GST_OBJECT_PARENT (ghostpad)), GST_PAD (ghostpad));
|
gst_element_remove_ghost_pad (GST_ELEMENT (GST_OBJECT_PARENT (ghostpad)), GST_PAD (ghostpad));
|
||||||
|
@ -2124,7 +2123,7 @@ gst_real_pad_dispose (GObject *object)
|
||||||
gst_caps_replace (&GST_RPAD_APPFILTER (pad), NULL);
|
gst_caps_replace (&GST_RPAD_APPFILTER (pad), NULL);
|
||||||
|
|
||||||
if (GST_IS_ELEMENT (GST_OBJECT_PARENT (pad))) {
|
if (GST_IS_ELEMENT (GST_OBJECT_PARENT (pad))) {
|
||||||
GST_DEBUG (GST_CAT_REFCOUNTING, "removing pad from element '%s'",
|
GST_CAT_DEBUG (GST_CAT_REFCOUNTING, "removing pad from element '%s'",
|
||||||
GST_OBJECT_NAME (GST_OBJECT (GST_ELEMENT (GST_OBJECT_PARENT (pad)))));
|
GST_OBJECT_NAME (GST_OBJECT (GST_ELEMENT (GST_OBJECT_PARENT (pad)))));
|
||||||
|
|
||||||
gst_element_remove_pad (GST_ELEMENT (GST_OBJECT_PARENT (pad)), pad);
|
gst_element_remove_pad (GST_ELEMENT (GST_OBJECT_PARENT (pad)), pad);
|
||||||
|
@ -2171,7 +2170,7 @@ gst_pad_load_and_link (xmlNodePtr self, GstObject *parent)
|
||||||
split = g_strsplit (peer, ".", 2);
|
split = g_strsplit (peer, ".", 2);
|
||||||
|
|
||||||
if (split[0] == NULL || split[1] == NULL) {
|
if (split[0] == NULL || split[1] == NULL) {
|
||||||
GST_DEBUG (GST_CAT_XML,
|
GST_CAT_DEBUG (GST_CAT_XML,
|
||||||
"Could not parse peer '%s' for pad %s:%s, leaving unlinked",
|
"Could not parse peer '%s' for pad %s:%s, leaving unlinked",
|
||||||
peer, GST_DEBUG_PAD_NAME (pad));
|
peer, GST_DEBUG_PAD_NAME (pad));
|
||||||
return;
|
return;
|
||||||
|
@ -2279,7 +2278,7 @@ gst_pad_push (GstPad *pad, GstBuffer *buf)
|
||||||
GstData *data = GST_DATA(buf);
|
GstData *data = GST_DATA(buf);
|
||||||
|
|
||||||
g_assert (GST_IS_PAD (pad));
|
g_assert (GST_IS_PAD (pad));
|
||||||
GST_DEBUG_ENTER ("(%s:%s)", GST_DEBUG_PAD_NAME (pad));
|
GST_CAT_LOG_OBJECT (GST_CAT_DATAFLOW, pad, "pushing");
|
||||||
|
|
||||||
g_return_if_fail (GST_PAD_DIRECTION (pad) == GST_PAD_SRC);
|
g_return_if_fail (GST_PAD_DIRECTION (pad) == GST_PAD_SRC);
|
||||||
|
|
||||||
|
@ -2301,7 +2300,7 @@ gst_pad_push (GstPad *pad, GstBuffer *buf)
|
||||||
|
|
||||||
if (peer->chainhandler) {
|
if (peer->chainhandler) {
|
||||||
if (data) {
|
if (data) {
|
||||||
GST_DEBUG (GST_CAT_DATAFLOW,
|
GST_CAT_LOG_OBJECT (GST_CAT_DATAFLOW, pad,
|
||||||
"calling chainhandler &%s of peer pad %s:%s",
|
"calling chainhandler &%s of peer pad %s:%s",
|
||||||
GST_DEBUG_FUNCPTR_NAME (peer->chainhandler),
|
GST_DEBUG_FUNCPTR_NAME (peer->chainhandler),
|
||||||
GST_DEBUG_PAD_NAME (GST_PAD (peer)));
|
GST_DEBUG_PAD_NAME (GST_PAD (peer)));
|
||||||
|
@ -2339,7 +2338,7 @@ gst_pad_pull (GstPad *pad)
|
||||||
{
|
{
|
||||||
GstRealPad *peer;
|
GstRealPad *peer;
|
||||||
|
|
||||||
GST_DEBUG_ENTER("(%s:%s)",GST_DEBUG_PAD_NAME(pad));
|
GST_CAT_LOG_OBJECT (GST_CAT_DATAFLOW, pad, "pulling");
|
||||||
|
|
||||||
g_return_val_if_fail (GST_PAD_DIRECTION (pad) == GST_PAD_SINK,
|
g_return_val_if_fail (GST_PAD_DIRECTION (pad) == GST_PAD_SINK,
|
||||||
GST_BUFFER (gst_event_new (GST_EVENT_INTERRUPT)));
|
GST_BUFFER (gst_event_new (GST_EVENT_INTERRUPT)));
|
||||||
|
@ -2357,7 +2356,8 @@ restart:
|
||||||
if (peer->gethandler) {
|
if (peer->gethandler) {
|
||||||
GstData *data;
|
GstData *data;
|
||||||
|
|
||||||
GST_DEBUG (GST_CAT_DATAFLOW, "calling gethandler %s of peer pad %s:%s",
|
GST_CAT_LOG_OBJECT (GST_CAT_DATAFLOW, pad,
|
||||||
|
"calling gethandler %s of peer pad %s:%s",
|
||||||
GST_DEBUG_FUNCPTR_NAME (peer->gethandler),
|
GST_DEBUG_FUNCPTR_NAME (peer->gethandler),
|
||||||
GST_DEBUG_PAD_NAME (peer));
|
GST_DEBUG_PAD_NAME (peer));
|
||||||
|
|
||||||
|
@ -2372,14 +2372,13 @@ restart:
|
||||||
/* no null buffers allowed */
|
/* no null buffers allowed */
|
||||||
gst_element_error (GST_PAD_PARENT (pad),
|
gst_element_error (GST_PAD_PARENT (pad),
|
||||||
"NULL buffer during pull on %s:%s",
|
"NULL buffer during pull on %s:%s",
|
||||||
GST_DEBUG_PAD_NAME (pad), NULL);
|
GST_DEBUG_PAD_NAME (pad));
|
||||||
|
|
||||||
} else {
|
} else {
|
||||||
gst_element_error (GST_PAD_PARENT (pad),
|
gst_element_error (GST_PAD_PARENT (pad),
|
||||||
"internal error: pull on pad %s:%s "
|
"internal error: pull on pad %s:%s "
|
||||||
"but the peer pad %s:%s has no gethandler",
|
"but the peer pad %s:%s has no gethandler",
|
||||||
GST_DEBUG_PAD_NAME (pad), GST_DEBUG_PAD_NAME (peer),
|
GST_DEBUG_PAD_NAME (pad), GST_DEBUG_PAD_NAME (peer));
|
||||||
NULL);
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
return GST_BUFFER (gst_event_new (GST_EVENT_INTERRUPT));
|
return GST_BUFFER (gst_event_new (GST_EVENT_INTERRUPT));
|
||||||
|
@ -2765,7 +2764,7 @@ gst_ghost_pad_new (const gchar *name,
|
||||||
|
|
||||||
/* FIXME need to ref the real pad here... ? */
|
/* FIXME need to ref the real pad here... ? */
|
||||||
|
|
||||||
GST_DEBUG (GST_CAT_PADS, "created ghost pad \"%s\"",
|
GST_CAT_DEBUG (GST_CAT_PADS, "created ghost pad \"%s\"",
|
||||||
gst_pad_get_name (GST_PAD (ghostpad)));
|
gst_pad_get_name (GST_PAD (ghostpad)));
|
||||||
|
|
||||||
return GST_PAD (ghostpad);
|
return GST_PAD (ghostpad);
|
||||||
|
@ -2980,13 +2979,13 @@ gst_pad_send_event (GstPad *pad, GstEvent *event)
|
||||||
if (GST_EVENT_SRC (event) == NULL)
|
if (GST_EVENT_SRC (event) == NULL)
|
||||||
GST_EVENT_SRC (event) = gst_object_ref (GST_OBJECT (rpad));
|
GST_EVENT_SRC (event) = gst_object_ref (GST_OBJECT (rpad));
|
||||||
|
|
||||||
GST_DEBUG (GST_CAT_EVENT, "have event %d on pad %s:%s",
|
GST_CAT_DEBUG (GST_CAT_EVENT, "have event %d on pad %s:%s",
|
||||||
GST_EVENT_TYPE (event), GST_DEBUG_PAD_NAME (rpad));
|
GST_EVENT_TYPE (event), GST_DEBUG_PAD_NAME (rpad));
|
||||||
|
|
||||||
if (GST_RPAD_EVENTHANDLER (rpad))
|
if (GST_RPAD_EVENTHANDLER (rpad))
|
||||||
success = GST_RPAD_EVENTHANDLER (rpad) (GST_PAD_CAST (rpad), event);
|
success = GST_RPAD_EVENTHANDLER (rpad) (GST_PAD_CAST (rpad), event);
|
||||||
else {
|
else {
|
||||||
GST_DEBUG (GST_CAT_EVENT, "there's no event function for pad %s:%s",
|
GST_CAT_DEBUG (GST_CAT_EVENT, "there's no event function for pad %s:%s",
|
||||||
GST_DEBUG_PAD_NAME (rpad));
|
GST_DEBUG_PAD_NAME (rpad));
|
||||||
gst_event_unref (event);
|
gst_event_unref (event);
|
||||||
}
|
}
|
||||||
|
|
|
@ -23,9 +23,10 @@
|
||||||
|
|
||||||
#include <string.h>
|
#include <string.h>
|
||||||
|
|
||||||
|
#include "gst_private.h"
|
||||||
|
|
||||||
#include "gstparse.h"
|
#include "gstparse.h"
|
||||||
#include "gstinfo.h"
|
#include "gstinfo.h"
|
||||||
#include "gstlog.h"
|
|
||||||
|
|
||||||
extern GstElement *_gst_parse_launch (const gchar *, GError **);
|
extern GstElement *_gst_parse_launch (const gchar *, GError **);
|
||||||
|
|
||||||
|
@ -118,7 +119,7 @@ gst_parse_launch (const gchar * pipeline_description, GError **error)
|
||||||
|
|
||||||
g_return_val_if_fail (pipeline_description != NULL, NULL);
|
g_return_val_if_fail (pipeline_description != NULL, NULL);
|
||||||
|
|
||||||
GST_INFO (GST_CAT_PIPELINE, "parsing pipeline description %s",
|
GST_CAT_INFO (GST_CAT_PIPELINE, "parsing pipeline description %s",
|
||||||
pipeline_description);
|
pipeline_description);
|
||||||
|
|
||||||
/* the need for the mutex will go away with flex 2.5.6 */
|
/* the need for the mutex will go away with flex 2.5.6 */
|
||||||
|
|
|
@ -23,7 +23,7 @@
|
||||||
#include "gst_private.h"
|
#include "gst_private.h"
|
||||||
|
|
||||||
#include "gstpipeline.h"
|
#include "gstpipeline.h"
|
||||||
#include "gstlog.h"
|
#include "gstinfo.h"
|
||||||
#include "gstscheduler.h"
|
#include "gstscheduler.h"
|
||||||
|
|
||||||
GstElementDetails gst_pipeline_details = {
|
GstElementDetails gst_pipeline_details = {
|
||||||
|
|
|
@ -26,10 +26,11 @@
|
||||||
#include <unistd.h>
|
#include <unistd.h>
|
||||||
|
|
||||||
#include "gst_private.h"
|
#include "gst_private.h"
|
||||||
|
|
||||||
#include "gstplugin.h"
|
#include "gstplugin.h"
|
||||||
#include "gstversion.h"
|
#include "gstversion.h"
|
||||||
#include "gstregistrypool.h"
|
#include "gstregistrypool.h"
|
||||||
#include "gstlog.h"
|
#include "gstinfo.h"
|
||||||
#include "config.h"
|
#include "config.h"
|
||||||
#include "gstfilter.h"
|
#include "gstfilter.h"
|
||||||
|
|
||||||
|
@ -98,7 +99,7 @@ static GstPlugin*
|
||||||
gst_plugin_register_func (GstPluginDesc *desc, GstPlugin *plugin, GModule *module)
|
gst_plugin_register_func (GstPluginDesc *desc, GstPlugin *plugin, GModule *module)
|
||||||
{
|
{
|
||||||
if (!gst_plugin_check_version (desc->major_version, desc->minor_version)) {
|
if (!gst_plugin_check_version (desc->major_version, desc->minor_version)) {
|
||||||
GST_INFO (GST_CAT_PLUGIN_LOADING,"plugin \"%s\" has incompatible version, not loading",
|
GST_CAT_INFO (GST_CAT_PLUGIN_LOADING,"plugin \"%s\" has incompatible version, not loading",
|
||||||
plugin->filename);
|
plugin->filename);
|
||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
|
@ -107,11 +108,11 @@ gst_plugin_register_func (GstPluginDesc *desc, GstPlugin *plugin, GModule *modul
|
||||||
plugin->name = g_strdup(desc->name);
|
plugin->name = g_strdup(desc->name);
|
||||||
|
|
||||||
if (!((desc->plugin_init) (module, plugin))) {
|
if (!((desc->plugin_init) (module, plugin))) {
|
||||||
GST_INFO (GST_CAT_PLUGIN_LOADING,"plugin \"%s\" failed to initialise",
|
GST_CAT_INFO (GST_CAT_PLUGIN_LOADING,"plugin \"%s\" failed to initialise",
|
||||||
plugin->filename);
|
plugin->filename);
|
||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
GST_INFO (GST_CAT_PLUGIN_LOADING,"plugin \"%s\" initialised", GST_STR_NULL (plugin->filename));
|
GST_CAT_INFO (GST_CAT_PLUGIN_LOADING,"plugin \"%s\" initialised", GST_STR_NULL (plugin->filename));
|
||||||
|
|
||||||
return plugin;
|
return plugin;
|
||||||
}
|
}
|
||||||
|
@ -157,7 +158,7 @@ gst_plugin_load_plugin (GstPlugin *plugin, GError **error)
|
||||||
|
|
||||||
filename = plugin->filename;
|
filename = plugin->filename;
|
||||||
|
|
||||||
GST_DEBUG (GST_CAT_PLUGIN_LOADING, "attempt to load plugin \"%s\"", filename);
|
GST_CAT_DEBUG (GST_CAT_PLUGIN_LOADING, "attempt to load plugin \"%s\"", filename);
|
||||||
|
|
||||||
if (g_module_supported () == FALSE) {
|
if (g_module_supported () == FALSE) {
|
||||||
g_set_error (error,
|
g_set_error (error,
|
||||||
|
@ -184,13 +185,13 @@ gst_plugin_load_plugin (GstPlugin *plugin, GError **error)
|
||||||
if (g_module_symbol (module, "plugin_desc", &ptr)) {
|
if (g_module_symbol (module, "plugin_desc", &ptr)) {
|
||||||
desc = (GstPluginDesc *)ptr;
|
desc = (GstPluginDesc *)ptr;
|
||||||
|
|
||||||
GST_DEBUG (GST_CAT_PLUGIN_LOADING, "plugin \"%s\" loaded, called entry function...", filename);
|
GST_CAT_DEBUG (GST_CAT_PLUGIN_LOADING, "plugin \"%s\" loaded, called entry function...", filename);
|
||||||
|
|
||||||
plugin->filename = g_strdup (filename);
|
plugin->filename = g_strdup (filename);
|
||||||
plugin = gst_plugin_register_func (desc, plugin, module);
|
plugin = gst_plugin_register_func (desc, plugin, module);
|
||||||
|
|
||||||
if (plugin != NULL) {
|
if (plugin != NULL) {
|
||||||
GST_INFO (GST_CAT_PLUGIN_LOADING, "plugin \"%s\" loaded", plugin->filename);
|
GST_CAT_INFO (GST_CAT_PLUGIN_LOADING, "plugin \"%s\" loaded", plugin->filename);
|
||||||
plugin->module = module;
|
plugin->module = module;
|
||||||
return TRUE;
|
return TRUE;
|
||||||
}
|
}
|
||||||
|
@ -242,11 +243,11 @@ gst_plugin_unload_plugin (GstPlugin *plugin)
|
||||||
|
|
||||||
if (g_module_close (plugin->module)) {
|
if (g_module_close (plugin->module)) {
|
||||||
plugin->module = NULL;
|
plugin->module = NULL;
|
||||||
GST_INFO (GST_CAT_PLUGIN_LOADING, "plugin \"%s\" unloaded", plugin->filename);
|
GST_CAT_INFO (GST_CAT_PLUGIN_LOADING, "plugin \"%s\" unloaded", plugin->filename);
|
||||||
return TRUE;
|
return TRUE;
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
GST_INFO (GST_CAT_PLUGIN_LOADING, "failed to unload plugin \"%s\"", plugin->filename);
|
GST_CAT_INFO (GST_CAT_PLUGIN_LOADING, "failed to unload plugin \"%s\"", plugin->filename);
|
||||||
return FALSE;
|
return FALSE;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -537,14 +538,14 @@ gst_plugin_load (const gchar *name)
|
||||||
if (plugin) {
|
if (plugin) {
|
||||||
gboolean result = gst_plugin_load_plugin (plugin, &error);
|
gboolean result = gst_plugin_load_plugin (plugin, &error);
|
||||||
if (error) {
|
if (error) {
|
||||||
GST_DEBUG (GST_CAT_PLUGIN_LOADING, "load_plugin error: %s\n",
|
GST_CAT_DEBUG (GST_CAT_PLUGIN_LOADING, "load_plugin error: %s\n",
|
||||||
error->message);
|
error->message);
|
||||||
g_error_free (error);
|
g_error_free (error);
|
||||||
}
|
}
|
||||||
return result;
|
return result;
|
||||||
}
|
}
|
||||||
|
|
||||||
GST_DEBUG (GST_CAT_PLUGIN_LOADING, "Could not find %s in registry pool",
|
GST_CAT_DEBUG (GST_CAT_PLUGIN_LOADING, "Could not find %s in registry pool",
|
||||||
name);
|
name);
|
||||||
|
|
||||||
return FALSE;
|
return FALSE;
|
||||||
|
|
|
@ -21,10 +21,11 @@
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#include "gst_private.h"
|
#include "gst_private.h"
|
||||||
|
|
||||||
#include "gstpluginfeature.h"
|
#include "gstpluginfeature.h"
|
||||||
#include "gstplugin.h"
|
#include "gstplugin.h"
|
||||||
#include "gstregistry.h"
|
#include "gstregistry.h"
|
||||||
#include "gstlog.h"
|
#include "gstinfo.h"
|
||||||
|
|
||||||
static void gst_plugin_feature_class_init (GstPluginFeatureClass *klass);
|
static void gst_plugin_feature_class_init (GstPluginFeatureClass *klass);
|
||||||
static void gst_plugin_feature_init (GstPluginFeature *feature);
|
static void gst_plugin_feature_init (GstPluginFeature *feature);
|
||||||
|
@ -94,7 +95,7 @@ gst_plugin_feature_ensure_loaded (GstPluginFeature *feature)
|
||||||
if (plugin && !gst_plugin_is_loaded (plugin)) {
|
if (plugin && !gst_plugin_is_loaded (plugin)) {
|
||||||
#ifndef GST_DISABLE_REGISTRY
|
#ifndef GST_DISABLE_REGISTRY
|
||||||
if (GST_IS_REGISTRY (plugin->manager)) {
|
if (GST_IS_REGISTRY (plugin->manager)) {
|
||||||
GST_DEBUG (GST_CAT_PLUGIN_LOADING,
|
GST_CAT_DEBUG (GST_CAT_PLUGIN_LOADING,
|
||||||
"loading plugin %s for feature", plugin->name);
|
"loading plugin %s for feature", plugin->name);
|
||||||
|
|
||||||
if (gst_registry_load_plugin (GST_REGISTRY (plugin->manager), plugin) != GST_REGISTRY_OK)
|
if (gst_registry_load_plugin (GST_REGISTRY (plugin->manager), plugin) != GST_REGISTRY_OK)
|
||||||
|
@ -135,4 +136,3 @@ gst_plugin_feature_type_name_filter (GstPluginFeature *feature,
|
||||||
return ((data->type == 0 || data->type == G_OBJECT_TYPE (feature)) &&
|
return ((data->type == 0 || data->type == G_OBJECT_TYPE (feature)) &&
|
||||||
(data->name == NULL || !strcmp (data->name, GST_PLUGIN_FEATURE_NAME (feature))));
|
(data->name == NULL || !strcmp (data->name, GST_PLUGIN_FEATURE_NAME (feature))));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -22,7 +22,7 @@
|
||||||
|
|
||||||
#include "gst_private.h"
|
#include "gst_private.h"
|
||||||
|
|
||||||
#include "gstlog.h"
|
#include "gstinfo.h"
|
||||||
#include "gstprops.h"
|
#include "gstprops.h"
|
||||||
#include "gstmemchunk.h"
|
#include "gstmemchunk.h"
|
||||||
|
|
||||||
|
@ -589,38 +589,39 @@ _gst_props_initialize (void)
|
||||||
static void
|
static void
|
||||||
gst_props_debug_entry (GstPropsEntry *entry)
|
gst_props_debug_entry (GstPropsEntry *entry)
|
||||||
{
|
{
|
||||||
const gchar *name = g_quark_to_string (entry->propid);
|
/* unused when debugging is disabled */
|
||||||
|
G_GNUC_UNUSED const gchar *name = g_quark_to_string (entry->propid);
|
||||||
|
|
||||||
switch (entry->propstype) {
|
switch (entry->propstype) {
|
||||||
case GST_PROPS_INT_TYPE:
|
case GST_PROPS_INT_TYPE:
|
||||||
GST_DEBUG (GST_CAT_PROPERTIES, "%p: %s: int %d", entry, name, entry->data.int_data);
|
GST_CAT_DEBUG (GST_CAT_PROPERTIES, "%p: %s: int %d", entry, name, entry->data.int_data);
|
||||||
break;
|
break;
|
||||||
case GST_PROPS_FLOAT_TYPE:
|
case GST_PROPS_FLOAT_TYPE:
|
||||||
GST_DEBUG (GST_CAT_PROPERTIES, "%p: %s: float %f", entry, name, entry->data.float_data);
|
GST_CAT_DEBUG (GST_CAT_PROPERTIES, "%p: %s: float %f", entry, name, entry->data.float_data);
|
||||||
break;
|
break;
|
||||||
case GST_PROPS_FOURCC_TYPE:
|
case GST_PROPS_FOURCC_TYPE:
|
||||||
GST_DEBUG (GST_CAT_PROPERTIES, "%p: %s: fourcc %c%c%c%c", entry, name,
|
GST_CAT_DEBUG (GST_CAT_PROPERTIES, "%p: %s: fourcc %c%c%c%c", entry, name,
|
||||||
(entry->data.fourcc_data>>0)&0xff,
|
(entry->data.fourcc_data>>0)&0xff,
|
||||||
(entry->data.fourcc_data>>8)&0xff,
|
(entry->data.fourcc_data>>8)&0xff,
|
||||||
(entry->data.fourcc_data>>16)&0xff,
|
(entry->data.fourcc_data>>16)&0xff,
|
||||||
(entry->data.fourcc_data>>24)&0xff);
|
(entry->data.fourcc_data>>24)&0xff);
|
||||||
break;
|
break;
|
||||||
case GST_PROPS_BOOLEAN_TYPE:
|
case GST_PROPS_BOOLEAN_TYPE:
|
||||||
GST_DEBUG (GST_CAT_PROPERTIES, "%p: %s: bool %d", entry, name, entry->data.bool_data);
|
GST_CAT_DEBUG (GST_CAT_PROPERTIES, "%p: %s: bool %d", entry, name, entry->data.bool_data);
|
||||||
break;
|
break;
|
||||||
case GST_PROPS_STRING_TYPE:
|
case GST_PROPS_STRING_TYPE:
|
||||||
GST_DEBUG (GST_CAT_PROPERTIES, "%p: %s: string \"%s\"", entry, name, entry->data.string_data.string);
|
GST_CAT_DEBUG (GST_CAT_PROPERTIES, "%p: %s: string \"%s\"", entry, name, entry->data.string_data.string);
|
||||||
break;
|
break;
|
||||||
case GST_PROPS_INT_RANGE_TYPE:
|
case GST_PROPS_INT_RANGE_TYPE:
|
||||||
GST_DEBUG (GST_CAT_PROPERTIES, "%p: %s: int range %d-%d", entry, name, entry->data.int_range_data.min,
|
GST_CAT_DEBUG (GST_CAT_PROPERTIES, "%p: %s: int range %d-%d", entry, name, entry->data.int_range_data.min,
|
||||||
entry->data.int_range_data.max);
|
entry->data.int_range_data.max);
|
||||||
break;
|
break;
|
||||||
case GST_PROPS_FLOAT_RANGE_TYPE:
|
case GST_PROPS_FLOAT_RANGE_TYPE:
|
||||||
GST_DEBUG (GST_CAT_PROPERTIES, "%p: %s: float range %f-%f", entry, name, entry->data.float_range_data.min,
|
GST_CAT_DEBUG (GST_CAT_PROPERTIES, "%p: %s: float range %f-%f", entry, name, entry->data.float_range_data.min,
|
||||||
entry->data.float_range_data.max);
|
entry->data.float_range_data.max);
|
||||||
break;
|
break;
|
||||||
case GST_PROPS_LIST_TYPE:
|
case GST_PROPS_LIST_TYPE:
|
||||||
GST_DEBUG (GST_CAT_PROPERTIES, "%p: [list]", entry);
|
GST_CAT_DEBUG (GST_CAT_PROPERTIES, "%p: [list]", entry);
|
||||||
g_list_foreach (entry->data.list_data.entries, (GFunc) gst_props_debug_entry, NULL);
|
g_list_foreach (entry->data.list_data.entries, (GFunc) gst_props_debug_entry, NULL);
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
|
@ -746,7 +747,7 @@ gst_props_alloc_entry (void)
|
||||||
gst_alloc_trace_new (_entries_trace, entry);
|
gst_alloc_trace_new (_entries_trace, entry);
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
GST_DEBUG (GST_CAT_PROPERTIES, "new entry %p", entry);
|
GST_CAT_LOG (GST_CAT_PROPERTIES, "new entry %p", entry);
|
||||||
|
|
||||||
return entry;
|
return entry;
|
||||||
}
|
}
|
||||||
|
@ -776,7 +777,7 @@ gst_props_entry_clean (GstPropsEntry *entry)
|
||||||
void
|
void
|
||||||
gst_props_entry_destroy (GstPropsEntry *entry)
|
gst_props_entry_destroy (GstPropsEntry *entry)
|
||||||
{
|
{
|
||||||
GST_DEBUG (GST_CAT_PROPERTIES, "destroy entry %p", entry);
|
GST_CAT_LOG (GST_CAT_PROPERTIES, "destroy entry %p", entry);
|
||||||
|
|
||||||
gst_props_entry_clean (entry);
|
gst_props_entry_clean (entry);
|
||||||
|
|
||||||
|
@ -809,7 +810,7 @@ gst_props_empty_new (void)
|
||||||
gst_alloc_trace_new (_props_trace, props);
|
gst_alloc_trace_new (_props_trace, props);
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
GST_DEBUG (GST_CAT_PROPERTIES, "new %p", props);
|
GST_CAT_LOG (GST_CAT_PROPERTIES, "new %p", props);
|
||||||
|
|
||||||
props->properties = NULL;
|
props->properties = NULL;
|
||||||
props->refcount = 1;
|
props->refcount = 1;
|
||||||
|
@ -972,11 +973,11 @@ void
|
||||||
gst_props_debug (GstProps *props)
|
gst_props_debug (GstProps *props)
|
||||||
{
|
{
|
||||||
if (!props) {
|
if (!props) {
|
||||||
GST_DEBUG (GST_CAT_PROPERTIES, "props (null)");
|
GST_CAT_DEBUG (GST_CAT_PROPERTIES, "props (null)");
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
GST_DEBUG (GST_CAT_PROPERTIES, "props %p, refcount %d, flags %d",
|
GST_CAT_DEBUG (GST_CAT_PROPERTIES, "props %p, refcount %d, flags %d",
|
||||||
props, props->refcount, props->flags);
|
props, props->refcount, props->flags);
|
||||||
|
|
||||||
g_list_foreach (props->properties, (GFunc) gst_props_debug_entry, NULL);
|
g_list_foreach (props->properties, (GFunc) gst_props_debug_entry, NULL);
|
||||||
|
@ -1350,7 +1351,7 @@ gst_props_unref (GstProps *props)
|
||||||
|
|
||||||
g_return_val_if_fail (props->refcount > 0, NULL);
|
g_return_val_if_fail (props->refcount > 0, NULL);
|
||||||
|
|
||||||
GST_DEBUG (GST_CAT_PROPERTIES, "unref %p (%d->%d)", props, props->refcount, props->refcount-1);
|
GST_CAT_LOG (GST_CAT_PROPERTIES, "unref %p (%d->%d)", props, props->refcount, props->refcount-1);
|
||||||
props->refcount--;
|
props->refcount--;
|
||||||
|
|
||||||
if (props->refcount == 0) {
|
if (props->refcount == 0) {
|
||||||
|
@ -1377,7 +1378,7 @@ gst_props_ref (GstProps *props)
|
||||||
|
|
||||||
g_return_val_if_fail (props->refcount > 0, NULL);
|
g_return_val_if_fail (props->refcount > 0, NULL);
|
||||||
|
|
||||||
GST_DEBUG (GST_CAT_PROPERTIES, "ref %p (%d->%d)", props, props->refcount, props->refcount+1);
|
GST_CAT_LOG (GST_CAT_PROPERTIES, "ref %p (%d->%d)", props, props->refcount, props->refcount+1);
|
||||||
|
|
||||||
props->refcount++;
|
props->refcount++;
|
||||||
|
|
||||||
|
@ -1397,7 +1398,7 @@ gst_props_sink (GstProps *props)
|
||||||
if (props == NULL)
|
if (props == NULL)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
GST_DEBUG (GST_CAT_PROPERTIES, "sink %p", props);
|
GST_CAT_LOG (GST_CAT_PROPERTIES, "sink %p", props);
|
||||||
|
|
||||||
if (GST_PROPS_IS_FLOATING (props)) {
|
if (GST_PROPS_IS_FLOATING (props)) {
|
||||||
GST_PROPS_FLAG_UNSET (props, GST_PROPS_FLOATING);
|
GST_PROPS_FLAG_UNSET (props, GST_PROPS_FLOATING);
|
||||||
|
@ -1958,7 +1959,7 @@ gst_props_entry_check_list_compatibility (GstPropsEntry *entry1, GstPropsEntry *
|
||||||
static gboolean
|
static gboolean
|
||||||
gst_props_entry_check_compatibility (GstPropsEntry *entry1, GstPropsEntry *entry2)
|
gst_props_entry_check_compatibility (GstPropsEntry *entry1, GstPropsEntry *entry2)
|
||||||
{
|
{
|
||||||
GST_DEBUG (GST_CAT_PROPERTIES,"compare: %s %s", g_quark_to_string (entry1->propid), g_quark_to_string (entry2->propid));
|
GST_CAT_DEBUG (GST_CAT_PROPERTIES,"compare: %s %s", g_quark_to_string (entry1->propid), g_quark_to_string (entry2->propid));
|
||||||
|
|
||||||
if (entry2->propstype == GST_PROPS_LIST_TYPE && entry1->propstype != GST_PROPS_LIST_TYPE) {
|
if (entry2->propstype == GST_PROPS_LIST_TYPE && entry1->propstype != GST_PROPS_LIST_TYPE) {
|
||||||
return gst_props_entry_check_list_compatibility (entry1, entry2);
|
return gst_props_entry_check_list_compatibility (entry1, entry2);
|
||||||
|
@ -2004,7 +2005,7 @@ gst_props_entry_check_compatibility (GstPropsEntry *entry1, GstPropsEntry *entry
|
||||||
switch (entry2->propstype) {
|
switch (entry2->propstype) {
|
||||||
/* b <---> a */
|
/* b <---> a */
|
||||||
case GST_PROPS_FOURCC_TYPE:
|
case GST_PROPS_FOURCC_TYPE:
|
||||||
GST_DEBUG(GST_CAT_PROPERTIES,"\"%c%c%c%c\" <--> \"%c%c%c%c\" ?",
|
GST_CAT_DEBUG (GST_CAT_PROPERTIES,"\"%c%c%c%c\" <--> \"%c%c%c%c\" ?",
|
||||||
(entry2->data.fourcc_data>>0)&0xff,
|
(entry2->data.fourcc_data>>0)&0xff,
|
||||||
(entry2->data.fourcc_data>>8)&0xff,
|
(entry2->data.fourcc_data>>8)&0xff,
|
||||||
(entry2->data.fourcc_data>>16)&0xff,
|
(entry2->data.fourcc_data>>16)&0xff,
|
||||||
|
@ -2022,13 +2023,13 @@ gst_props_entry_check_compatibility (GstPropsEntry *entry1, GstPropsEntry *entry
|
||||||
switch (entry2->propstype) {
|
switch (entry2->propstype) {
|
||||||
/* b <---> a - d */
|
/* b <---> a - d */
|
||||||
case GST_PROPS_INT_RANGE_TYPE:
|
case GST_PROPS_INT_RANGE_TYPE:
|
||||||
GST_DEBUG(GST_CAT_PROPERTIES,"%d <= %d <= %d ?",entry2->data.int_range_data.min,
|
GST_CAT_DEBUG (GST_CAT_PROPERTIES,"%d <= %d <= %d ?",entry2->data.int_range_data.min,
|
||||||
entry1->data.int_data,entry2->data.int_range_data.max);
|
entry1->data.int_data,entry2->data.int_range_data.max);
|
||||||
return (entry2->data.int_range_data.min <= entry1->data.int_data &&
|
return (entry2->data.int_range_data.min <= entry1->data.int_data &&
|
||||||
entry2->data.int_range_data.max >= entry1->data.int_data);
|
entry2->data.int_range_data.max >= entry1->data.int_data);
|
||||||
/* b <---> a */
|
/* b <---> a */
|
||||||
case GST_PROPS_INT_TYPE:
|
case GST_PROPS_INT_TYPE:
|
||||||
GST_DEBUG(GST_CAT_PROPERTIES,"%d == %d ?",entry1->data.int_data,entry2->data.int_data);
|
GST_CAT_DEBUG (GST_CAT_PROPERTIES,"%d == %d ?",entry1->data.int_data,entry2->data.int_data);
|
||||||
return (entry2->data.int_data == entry1->data.int_data);
|
return (entry2->data.int_data == entry1->data.int_data);
|
||||||
default:
|
default:
|
||||||
break;
|
break;
|
||||||
|
@ -2059,7 +2060,7 @@ gst_props_entry_check_compatibility (GstPropsEntry *entry1, GstPropsEntry *entry
|
||||||
switch (entry2->propstype) {
|
switch (entry2->propstype) {
|
||||||
/* t <---> t */
|
/* t <---> t */
|
||||||
case GST_PROPS_STRING_TYPE:
|
case GST_PROPS_STRING_TYPE:
|
||||||
GST_DEBUG(GST_CAT_PROPERTIES,"\"%s\" <--> \"%s\" ?",
|
GST_CAT_DEBUG (GST_CAT_PROPERTIES,"\"%s\" <--> \"%s\" ?",
|
||||||
entry2->data.string_data.string, entry1->data.string_data.string);
|
entry2->data.string_data.string, entry1->data.string_data.string);
|
||||||
return (!strcmp (entry2->data.string_data.string, entry1->data.string_data.string));
|
return (!strcmp (entry2->data.string_data.string, entry1->data.string_data.string));
|
||||||
default:
|
default:
|
||||||
|
@ -2118,7 +2119,7 @@ gst_props_check_compatibility (GstProps *fromprops, GstProps *toprops)
|
||||||
|
|
||||||
if (!gst_props_entry_check_compatibility (entry1, entry2)) {
|
if (!gst_props_entry_check_compatibility (entry1, entry2)) {
|
||||||
compatible = FALSE;
|
compatible = FALSE;
|
||||||
GST_DEBUG (GST_CAT_PROPERTIES, "%s are not compatible: ",
|
GST_CAT_DEBUG (GST_CAT_PROPERTIES, "%s are not compatible: ",
|
||||||
g_quark_to_string (entry1->propid));
|
g_quark_to_string (entry1->propid));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -21,23 +21,13 @@
|
||||||
* Boston, MA 02111-1307, USA.
|
* Boston, MA 02111-1307, USA.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
/* #define DEBUG_ENABLED */
|
|
||||||
/* #define STATUS_ENABLED */
|
|
||||||
|
|
||||||
#ifdef STATUS_ENABLED
|
|
||||||
#define STATUS(A) GST_DEBUG(GST_CAT_DATAFLOW, A, GST_ELEMENT_NAME(queue))
|
|
||||||
#else
|
|
||||||
#define STATUS(A)
|
|
||||||
#endif
|
|
||||||
|
|
||||||
|
|
||||||
#include "config.h"
|
|
||||||
#include "gst_private.h"
|
#include "gst_private.h"
|
||||||
|
|
||||||
#include "gstqueue.h"
|
#include "gstqueue.h"
|
||||||
#include "gstscheduler.h"
|
#include "gstscheduler.h"
|
||||||
#include "gstevent.h"
|
#include "gstevent.h"
|
||||||
#include "gstlog.h"
|
#include "gstinfo.h"
|
||||||
|
|
||||||
GstElementDetails gst_queue_details = {
|
GstElementDetails gst_queue_details = {
|
||||||
"Queue",
|
"Queue",
|
||||||
|
@ -253,7 +243,7 @@ gst_queue_init (GstQueue *queue)
|
||||||
queue->not_full = g_cond_new ();
|
queue->not_full = g_cond_new ();
|
||||||
queue->events = g_async_queue_new();
|
queue->events = g_async_queue_new();
|
||||||
queue->queue = g_queue_new ();
|
queue->queue = g_queue_new ();
|
||||||
GST_DEBUG_ELEMENT (GST_CAT_THREAD, queue, "initialized queue's not_empty & not_full conditions");
|
GST_CAT_DEBUG_OBJECT (GST_CAT_THREAD, queue, "initialized queue's not_empty & not_full conditions");
|
||||||
}
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
|
@ -286,7 +276,7 @@ gst_queue_get_bufferpool (GstPad *pad)
|
||||||
static void
|
static void
|
||||||
gst_queue_cleanup_data (gpointer data, const gpointer user_data)
|
gst_queue_cleanup_data (gpointer data, const gpointer user_data)
|
||||||
{
|
{
|
||||||
GST_DEBUG_ELEMENT (GST_CAT_DATAFLOW, user_data, "cleaning buffer %p", data);
|
GST_CAT_DEBUG_OBJECT (GST_CAT_DATAFLOW, user_data, "cleaning buffer %p", data);
|
||||||
|
|
||||||
gst_data_unref (GST_DATA (data));
|
gst_data_unref (GST_DATA (data));
|
||||||
}
|
}
|
||||||
|
@ -324,17 +314,17 @@ gst_queue_chain (GstPad *pad, GstBuffer *buf)
|
||||||
g_async_queue_lock(queue->events);
|
g_async_queue_lock(queue->events);
|
||||||
while (g_async_queue_length_unlocked(queue->events) > 0){
|
while (g_async_queue_length_unlocked(queue->events) > 0){
|
||||||
GstEvent *event = (GstEvent*)g_async_queue_pop_unlocked(queue->events);
|
GstEvent *event = (GstEvent*)g_async_queue_pop_unlocked(queue->events);
|
||||||
GST_DEBUG_ELEMENT (GST_CAT_DATAFLOW, queue, "sending event upstream\n");
|
GST_CAT_DEBUG_OBJECT (GST_CAT_DATAFLOW, queue, "sending event upstream\n");
|
||||||
gst_pad_event_default (pad, event);
|
gst_pad_event_default (pad, event);
|
||||||
GST_DEBUG_ELEMENT (GST_CAT_DATAFLOW, queue, "event sent\n");
|
GST_CAT_DEBUG_OBJECT (GST_CAT_DATAFLOW, queue, "event sent\n");
|
||||||
}
|
}
|
||||||
g_async_queue_unlock(queue->events);
|
g_async_queue_unlock(queue->events);
|
||||||
|
|
||||||
restart:
|
restart:
|
||||||
/* we have to lock the queue since we span threads */
|
/* we have to lock the queue since we span threads */
|
||||||
GST_DEBUG_ELEMENT (GST_CAT_DATAFLOW, queue, "locking t:%p", g_thread_self ());
|
GST_CAT_LOG_OBJECT (GST_CAT_DATAFLOW, queue, "locking t:%p", g_thread_self ());
|
||||||
g_mutex_lock (queue->qlock);
|
g_mutex_lock (queue->qlock);
|
||||||
GST_DEBUG_ELEMENT (GST_CAT_DATAFLOW, queue, "locked t:%p", g_thread_self ());
|
GST_CAT_LOG_OBJECT (GST_CAT_DATAFLOW, queue, "locked t:%p", g_thread_self ());
|
||||||
|
|
||||||
/* assume don't need to flush this buffer when the queue is filled */
|
/* assume don't need to flush this buffer when the queue is filled */
|
||||||
queue->flush = FALSE;
|
queue->flush = FALSE;
|
||||||
|
@ -342,11 +332,11 @@ restart:
|
||||||
if (GST_IS_EVENT (buf)) {
|
if (GST_IS_EVENT (buf)) {
|
||||||
switch (GST_EVENT_TYPE (buf)) {
|
switch (GST_EVENT_TYPE (buf)) {
|
||||||
case GST_EVENT_FLUSH:
|
case GST_EVENT_FLUSH:
|
||||||
GST_DEBUG_ELEMENT (GST_CAT_DATAFLOW, queue, "FLUSH event, flushing queue\n");
|
GST_CAT_DEBUG_OBJECT (GST_CAT_DATAFLOW, queue, "FLUSH event, flushing queue\n");
|
||||||
gst_queue_locked_flush (queue);
|
gst_queue_locked_flush (queue);
|
||||||
break;
|
break;
|
||||||
case GST_EVENT_EOS:
|
case GST_EVENT_EOS:
|
||||||
GST_DEBUG_ELEMENT (GST_CAT_DATAFLOW, queue, "eos in on %s %d\n",
|
GST_CAT_DEBUG_OBJECT (GST_CAT_DATAFLOW, queue, "eos in on %s %d\n",
|
||||||
GST_ELEMENT_NAME (queue), queue->level_buffers);
|
GST_ELEMENT_NAME (queue), queue->level_buffers);
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
|
@ -355,7 +345,7 @@ restart:
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
GST_DEBUG_ELEMENT (GST_CAT_DATAFLOW, queue, "adding buffer %p of size %d",buf,GST_BUFFER_SIZE(buf));
|
GST_CAT_LOG_OBJECT (GST_CAT_DATAFLOW, queue, "adding buffer %p of size %d",buf,GST_BUFFER_SIZE(buf));
|
||||||
|
|
||||||
if (queue->level_buffers == queue->size_buffers) {
|
if (queue->level_buffers == queue->size_buffers) {
|
||||||
g_mutex_unlock (queue->qlock);
|
g_mutex_unlock (queue->qlock);
|
||||||
|
@ -367,7 +357,7 @@ restart:
|
||||||
/* FIXME don't want to leak events! */
|
/* FIXME don't want to leak events! */
|
||||||
/* if we leak on the upstream side, drop the current buffer */
|
/* if we leak on the upstream side, drop the current buffer */
|
||||||
if (queue->leaky == GST_QUEUE_LEAK_UPSTREAM) {
|
if (queue->leaky == GST_QUEUE_LEAK_UPSTREAM) {
|
||||||
GST_DEBUG_ELEMENT (GST_CAT_DATAFLOW, queue, "queue is full, leaking buffer on upstream end");
|
GST_CAT_DEBUG_OBJECT (GST_CAT_DATAFLOW, queue, "queue is full, leaking buffer on upstream end");
|
||||||
if (GST_IS_EVENT (buf))
|
if (GST_IS_EVENT (buf))
|
||||||
fprintf(stderr, "Error: queue [%s] leaked an event, type:%d\n",
|
fprintf(stderr, "Error: queue [%s] leaked an event, type:%d\n",
|
||||||
GST_ELEMENT_NAME(GST_ELEMENT(queue)),
|
GST_ELEMENT_NAME(GST_ELEMENT(queue)),
|
||||||
|
@ -381,7 +371,7 @@ restart:
|
||||||
gpointer front;
|
gpointer front;
|
||||||
GstBuffer *leakbuf;
|
GstBuffer *leakbuf;
|
||||||
|
|
||||||
GST_DEBUG_ELEMENT (GST_CAT_DATAFLOW, queue, "queue is full, leaking buffer on downstream end");
|
GST_CAT_DEBUG_OBJECT (GST_CAT_DATAFLOW, queue, "queue is full, leaking buffer on downstream end");
|
||||||
|
|
||||||
front = g_queue_pop_head (queue->queue);
|
front = g_queue_pop_head (queue->queue);
|
||||||
leakbuf = (GstBuffer *)(front);
|
leakbuf = (GstBuffer *)(front);
|
||||||
|
@ -397,24 +387,24 @@ restart:
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
GST_DEBUG_ELEMENT (GST_CAT_DATAFLOW, queue, "pre full wait, level:%d/%d buffers, %d bytes",
|
GST_CAT_LOG_OBJECT (GST_CAT_DATAFLOW, queue, "pre full wait, level:%d/%d buffers, %d bytes",
|
||||||
queue->level_buffers, queue->size_buffers, queue->level_bytes);
|
queue->level_buffers, queue->size_buffers, queue->level_bytes);
|
||||||
|
|
||||||
while (queue->level_buffers == queue->size_buffers) {
|
while (queue->level_buffers == queue->size_buffers) {
|
||||||
/* if there's a pending state change for this queue or its manager, switch */
|
/* if there's a pending state change for this queue or its manager, switch */
|
||||||
/* back to iterator so bottom half of state change executes */
|
/* back to iterator so bottom half of state change executes */
|
||||||
if (queue->interrupt) {
|
if (queue->interrupt) {
|
||||||
GST_DEBUG_ELEMENT (GST_CAT_DATAFLOW, queue, "interrupted!!");
|
GST_CAT_DEBUG_OBJECT (GST_CAT_DATAFLOW, queue, "interrupted!!");
|
||||||
g_mutex_unlock (queue->qlock);
|
g_mutex_unlock (queue->qlock);
|
||||||
if (gst_scheduler_interrupt (gst_pad_get_scheduler (queue->sinkpad), GST_ELEMENT (queue)))
|
if (gst_scheduler_interrupt (gst_pad_get_scheduler (queue->sinkpad), GST_ELEMENT (queue)))
|
||||||
goto out_unref;
|
goto out_unref;
|
||||||
/* if we got here because we were unlocked after a flush, we don't need
|
/* if we got here because we were unlocked after a flush, we don't need
|
||||||
* to add the buffer to the queue again */
|
* to add the buffer to the queue again */
|
||||||
if (queue->flush) {
|
if (queue->flush) {
|
||||||
GST_DEBUG_ELEMENT (GST_CAT_DATAFLOW, queue, "not adding pending buffer after flush");
|
GST_CAT_DEBUG_OBJECT (GST_CAT_DATAFLOW, queue, "not adding pending buffer after flush");
|
||||||
goto out_unref;
|
goto out_unref;
|
||||||
}
|
}
|
||||||
GST_DEBUG_ELEMENT (GST_CAT_DATAFLOW, queue, "adding pending buffer after interrupt");
|
GST_CAT_DEBUG_OBJECT (GST_CAT_DATAFLOW, queue, "adding pending buffer after interrupt");
|
||||||
goto restart;
|
goto restart;
|
||||||
}
|
}
|
||||||
if (GST_STATE (queue) != GST_STATE_PLAYING) {
|
if (GST_STATE (queue) != GST_STATE_PLAYING) {
|
||||||
|
@ -432,12 +422,12 @@ restart:
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
GST_DEBUG_ELEMENT (GST_CAT_DATAFLOW, queue, "waiting for not_full, level:%d/%d buffers, %d bytes",
|
GST_CAT_DEBUG_OBJECT (GST_CAT_DATAFLOW, queue, "waiting for not_full, level:%d/%d buffers, %d bytes",
|
||||||
queue->level_buffers, queue->size_buffers, queue->level_bytes);
|
queue->level_buffers, queue->size_buffers, queue->level_bytes);
|
||||||
g_cond_wait (queue->not_full, queue->qlock);
|
g_cond_wait (queue->not_full, queue->qlock);
|
||||||
GST_DEBUG_ELEMENT (GST_CAT_DATAFLOW, queue, "got not_full signal");
|
GST_CAT_DEBUG_OBJECT (GST_CAT_DATAFLOW, queue, "got not_full signal");
|
||||||
}
|
}
|
||||||
GST_DEBUG_ELEMENT (GST_CAT_DATAFLOW, queue, "post full wait, level:%d/%d buffers, %d bytes",
|
GST_CAT_LOG_OBJECT (GST_CAT_DATAFLOW, queue, "post full wait, level:%d/%d buffers, %d bytes",
|
||||||
queue->level_buffers, queue->size_buffers, queue->level_bytes);
|
queue->level_buffers, queue->size_buffers, queue->level_bytes);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -450,11 +440,11 @@ restart:
|
||||||
/* this assertion _has_ to hold */
|
/* this assertion _has_ to hold */
|
||||||
g_assert (queue->queue->length == queue->level_buffers);
|
g_assert (queue->queue->length == queue->level_buffers);
|
||||||
|
|
||||||
GST_DEBUG_ELEMENT (GST_CAT_DATAFLOW, queue, "(%s:%s)+ level:%d/%d buffers, %d bytes",
|
GST_CAT_LOG_OBJECT (GST_CAT_DATAFLOW, queue, "(%s:%s)+ level:%d/%d buffers, %d bytes",
|
||||||
GST_DEBUG_PAD_NAME(pad),
|
GST_DEBUG_PAD_NAME(pad),
|
||||||
queue->level_buffers, queue->size_buffers, queue->level_bytes);
|
queue->level_buffers, queue->size_buffers, queue->level_bytes);
|
||||||
|
|
||||||
GST_DEBUG_ELEMENT (GST_CAT_DATAFLOW, queue, "signalling not_empty");
|
GST_CAT_LOG_OBJECT (GST_CAT_DATAFLOW, queue, "signalling not_empty");
|
||||||
g_cond_signal (queue->not_empty);
|
g_cond_signal (queue->not_empty);
|
||||||
g_mutex_unlock (queue->qlock);
|
g_mutex_unlock (queue->qlock);
|
||||||
|
|
||||||
|
@ -481,11 +471,11 @@ gst_queue_get (GstPad *pad)
|
||||||
|
|
||||||
restart:
|
restart:
|
||||||
/* have to lock for thread-safety */
|
/* have to lock for thread-safety */
|
||||||
GST_DEBUG_ELEMENT (GST_CAT_DATAFLOW, queue, "locking t:%p", g_thread_self ());
|
GST_CAT_LOG_OBJECT (GST_CAT_DATAFLOW, queue, "locking t:%p", g_thread_self ());
|
||||||
g_mutex_lock (queue->qlock);
|
g_mutex_lock (queue->qlock);
|
||||||
GST_DEBUG_ELEMENT (GST_CAT_DATAFLOW, queue, "locked t:%p %p", g_thread_self (), queue->not_empty);
|
GST_CAT_LOG_OBJECT (GST_CAT_DATAFLOW, queue, "locked t:%p %p", g_thread_self (), queue->not_empty);
|
||||||
|
|
||||||
GST_DEBUG_ELEMENT (GST_CAT_DATAFLOW, queue, "pre empty wait, level:%d/%d buffers, %d bytes",
|
GST_CAT_LOG_OBJECT (GST_CAT_DATAFLOW, queue, "pre empty wait, level:%d/%d buffers, %d bytes",
|
||||||
queue->level_buffers, queue->size_buffers, queue->level_bytes);
|
queue->level_buffers, queue->size_buffers, queue->level_bytes);
|
||||||
while (queue->level_buffers == 0) {
|
while (queue->level_buffers == 0) {
|
||||||
/* if there's a pending state change for this queue or its manager, switch
|
/* if there's a pending state change for this queue or its manager, switch
|
||||||
|
@ -493,7 +483,7 @@ restart:
|
||||||
*/
|
*/
|
||||||
//while (GST_STATE_PENDING (queue) != GST_STATE_VOID_PENDING) {
|
//while (GST_STATE_PENDING (queue) != GST_STATE_VOID_PENDING) {
|
||||||
if (queue->interrupt) {
|
if (queue->interrupt) {
|
||||||
GST_DEBUG_ELEMENT (GST_CAT_DATAFLOW, queue, "interrupted!!");
|
GST_CAT_DEBUG_OBJECT (GST_CAT_DATAFLOW, queue, "interrupted!!");
|
||||||
g_mutex_unlock (queue->qlock);
|
g_mutex_unlock (queue->qlock);
|
||||||
if (gst_scheduler_interrupt (gst_pad_get_scheduler (queue->srcpad), GST_ELEMENT (queue)))
|
if (gst_scheduler_interrupt (gst_pad_get_scheduler (queue->srcpad), GST_ELEMENT (queue)))
|
||||||
return GST_BUFFER (gst_event_new (GST_EVENT_INTERRUPT));
|
return GST_BUFFER (gst_event_new (GST_EVENT_INTERRUPT));
|
||||||
|
@ -511,7 +501,7 @@ restart:
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
GST_DEBUG_ELEMENT (GST_CAT_DATAFLOW, queue, "waiting for not_empty, level:%d/%d buffers, %d bytes",
|
GST_CAT_DEBUG_OBJECT (GST_CAT_DATAFLOW, queue, "waiting for not_empty, level:%d/%d buffers, %d bytes",
|
||||||
queue->level_buffers, queue->size_buffers, queue->level_bytes);
|
queue->level_buffers, queue->size_buffers, queue->level_bytes);
|
||||||
|
|
||||||
/* if (queue->block_timeout > -1){ */
|
/* if (queue->block_timeout > -1){ */
|
||||||
|
@ -528,26 +518,26 @@ restart:
|
||||||
else {
|
else {
|
||||||
g_cond_wait (queue->not_empty, queue->qlock);
|
g_cond_wait (queue->not_empty, queue->qlock);
|
||||||
}
|
}
|
||||||
GST_DEBUG_ELEMENT (GST_CAT_DATAFLOW, queue, "got not_empty signal");
|
GST_CAT_DEBUG_OBJECT (GST_CAT_DATAFLOW, queue, "got not_empty signal");
|
||||||
}
|
}
|
||||||
GST_DEBUG_ELEMENT (GST_CAT_DATAFLOW, queue, "post empty wait, level:%d/%d buffers, %d bytes",
|
GST_CAT_LOG_OBJECT (GST_CAT_DATAFLOW, queue, "post empty wait, level:%d/%d buffers, %d bytes",
|
||||||
queue->level_buffers, queue->size_buffers, queue->level_bytes);
|
queue->level_buffers, queue->size_buffers, queue->level_bytes);
|
||||||
|
|
||||||
front = g_queue_pop_head (queue->queue);
|
front = g_queue_pop_head (queue->queue);
|
||||||
buf = (GstBuffer *)(front);
|
buf = (GstBuffer *)(front);
|
||||||
GST_DEBUG_ELEMENT (GST_CAT_DATAFLOW, queue, "retrieved buffer %p from queue", buf);
|
GST_CAT_LOG_OBJECT (GST_CAT_DATAFLOW, queue, "retrieved buffer %p from queue", buf);
|
||||||
|
|
||||||
queue->level_buffers--;
|
queue->level_buffers--;
|
||||||
queue->level_bytes -= GST_BUFFER_SIZE(buf);
|
queue->level_bytes -= GST_BUFFER_SIZE(buf);
|
||||||
|
|
||||||
GST_DEBUG_ELEMENT (GST_CAT_DATAFLOW, queue, "(%s:%s)- level:%d/%d buffers, %d bytes",
|
GST_CAT_LOG_OBJECT (GST_CAT_DATAFLOW, queue, "(%s:%s)- level:%d/%d buffers, %d bytes",
|
||||||
GST_DEBUG_PAD_NAME(pad),
|
GST_DEBUG_PAD_NAME(pad),
|
||||||
queue->level_buffers, queue->size_buffers, queue->level_bytes);
|
queue->level_buffers, queue->size_buffers, queue->level_bytes);
|
||||||
|
|
||||||
/* this assertion _has_ to hold */
|
/* this assertion _has_ to hold */
|
||||||
g_assert (queue->queue->length == queue->level_buffers);
|
g_assert (queue->queue->length == queue->level_buffers);
|
||||||
|
|
||||||
GST_DEBUG_ELEMENT (GST_CAT_DATAFLOW, queue, "signalling not_full");
|
GST_CAT_LOG_OBJECT (GST_CAT_DATAFLOW, queue, "signalling not_full");
|
||||||
g_cond_signal (queue->not_full);
|
g_cond_signal (queue->not_full);
|
||||||
|
|
||||||
g_mutex_unlock (queue->qlock);
|
g_mutex_unlock (queue->qlock);
|
||||||
|
@ -557,7 +547,7 @@ restart:
|
||||||
GstEvent *event = GST_EVENT(buf);
|
GstEvent *event = GST_EVENT(buf);
|
||||||
switch (GST_EVENT_TYPE(event)) {
|
switch (GST_EVENT_TYPE(event)) {
|
||||||
case GST_EVENT_EOS:
|
case GST_EVENT_EOS:
|
||||||
GST_DEBUG_ELEMENT (GST_CAT_DATAFLOW, queue, "queue \"%s\" eos", GST_ELEMENT_NAME (queue));
|
GST_CAT_DEBUG_OBJECT (GST_CAT_DATAFLOW, queue, "queue \"%s\" eos", GST_ELEMENT_NAME (queue));
|
||||||
gst_element_set_eos (GST_ELEMENT (queue));
|
gst_element_set_eos (GST_ELEMENT (queue));
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
|
@ -599,7 +589,7 @@ gst_queue_handle_src_event (GstPad *pad, GstEvent *event)
|
||||||
|
|
||||||
switch (event_type) {
|
switch (event_type) {
|
||||||
case GST_EVENT_FLUSH:
|
case GST_EVENT_FLUSH:
|
||||||
GST_DEBUG_ELEMENT (GST_CAT_DATAFLOW, queue, "FLUSH event, flushing queue\n");
|
GST_CAT_DEBUG_OBJECT (GST_CAT_DATAFLOW, queue, "FLUSH event, flushing queue\n");
|
||||||
gst_queue_locked_flush (queue);
|
gst_queue_locked_flush (queue);
|
||||||
break;
|
break;
|
||||||
case GST_EVENT_SEEK:
|
case GST_EVENT_SEEK:
|
||||||
|
@ -641,7 +631,7 @@ gst_queue_change_state (GstElement *element)
|
||||||
|
|
||||||
queue = GST_QUEUE (element);
|
queue = GST_QUEUE (element);
|
||||||
|
|
||||||
GST_DEBUG_ENTER("('%s')", GST_ELEMENT_NAME (element));
|
GST_CAT_LOG_OBJECT (GST_CAT_STATES, element, "starting state change");
|
||||||
|
|
||||||
/* lock the queue so another thread (not in sync with this thread's state)
|
/* lock the queue so another thread (not in sync with this thread's state)
|
||||||
* can't call this queue's _get (or whatever)
|
* can't call this queue's _get (or whatever)
|
||||||
|
@ -656,7 +646,7 @@ gst_queue_change_state (GstElement *element)
|
||||||
break;
|
break;
|
||||||
case GST_STATE_PAUSED_TO_PLAYING:
|
case GST_STATE_PAUSED_TO_PLAYING:
|
||||||
if (!GST_PAD_IS_LINKED (queue->sinkpad)) {
|
if (!GST_PAD_IS_LINKED (queue->sinkpad)) {
|
||||||
GST_DEBUG_ELEMENT (GST_CAT_STATES, queue, "queue %s is not linked", GST_ELEMENT_NAME (queue));
|
GST_CAT_DEBUG_OBJECT (GST_CAT_STATES, queue, "queue %s is not linked", GST_ELEMENT_NAME (queue));
|
||||||
/* FIXME can this be? */
|
/* FIXME can this be? */
|
||||||
g_cond_signal (queue->not_empty);
|
g_cond_signal (queue->not_empty);
|
||||||
|
|
||||||
|
@ -670,7 +660,7 @@ gst_queue_change_state (GstElement *element)
|
||||||
sink_sched = gst_pad_get_scheduler (GST_PAD_CAST (queue->sinkpad));
|
sink_sched = gst_pad_get_scheduler (GST_PAD_CAST (queue->sinkpad));
|
||||||
|
|
||||||
if (src_sched == sink_sched) {
|
if (src_sched == sink_sched) {
|
||||||
GST_DEBUG_ELEMENT (GST_CAT_STATES, queue, "queue %s does not connect different schedulers",
|
GST_CAT_DEBUG_OBJECT (GST_CAT_STATES, queue, "queue %s does not connect different schedulers",
|
||||||
GST_ELEMENT_NAME (queue));
|
GST_ELEMENT_NAME (queue));
|
||||||
|
|
||||||
g_warning ("queue %s does not connect different schedulers",
|
g_warning ("queue %s does not connect different schedulers",
|
||||||
|
@ -696,7 +686,7 @@ gst_queue_change_state (GstElement *element)
|
||||||
error:
|
error:
|
||||||
g_mutex_unlock (queue->qlock);
|
g_mutex_unlock (queue->qlock);
|
||||||
|
|
||||||
GST_DEBUG_LEAVE("('%s')", GST_ELEMENT_NAME (element));
|
GST_CAT_LOG_OBJECT (GST_CAT_STATES, element, "done with state change");
|
||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -28,6 +28,8 @@
|
||||||
#include <stdio.h>
|
#include <stdio.h>
|
||||||
#include <string.h>
|
#include <string.h>
|
||||||
|
|
||||||
|
#include "gst_private.h"
|
||||||
|
|
||||||
#include "gstinfo.h"
|
#include "gstinfo.h"
|
||||||
#include "gstregistry.h"
|
#include "gstregistry.h"
|
||||||
#include "gstlog.h"
|
#include "gstlog.h"
|
||||||
|
@ -487,4 +489,3 @@ gst_registry_update_plugin (GstRegistry *registry, GstPlugin *plugin)
|
||||||
|
|
||||||
return GST_REGISTRY_PLUGIN_LOAD_ERROR;
|
return GST_REGISTRY_PLUGIN_LOAD_ERROR;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -22,6 +22,8 @@
|
||||||
|
|
||||||
#include <string.h>
|
#include <string.h>
|
||||||
|
|
||||||
|
#include "gst_private.h"
|
||||||
|
|
||||||
#include "gstinfo.h"
|
#include "gstinfo.h"
|
||||||
#include "gstregistrypool.h"
|
#include "gstregistrypool.h"
|
||||||
#include "gstlog.h"
|
#include "gstlog.h"
|
||||||
|
@ -326,4 +328,3 @@ gst_registry_pool_get_prefered (GstRegistryFlags flags)
|
||||||
#endif /* GST_DISABLE_REGISTRY */
|
#endif /* GST_DISABLE_REGISTRY */
|
||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -24,7 +24,7 @@
|
||||||
|
|
||||||
#include "gstsystemclock.h"
|
#include "gstsystemclock.h"
|
||||||
#include "gstscheduler.h"
|
#include "gstscheduler.h"
|
||||||
#include "gstlog.h"
|
#include "gstinfo.h"
|
||||||
#include "gstregistrypool.h"
|
#include "gstregistrypool.h"
|
||||||
|
|
||||||
static void gst_scheduler_class_init (GstSchedulerClass *klass);
|
static void gst_scheduler_class_init (GstSchedulerClass *klass);
|
||||||
|
@ -90,7 +90,7 @@ gst_scheduler_dispose (GObject *object)
|
||||||
GstScheduler *sched = GST_SCHEDULER (object);
|
GstScheduler *sched = GST_SCHEDULER (object);
|
||||||
|
|
||||||
/* thse lists should all be NULL */
|
/* thse lists should all be NULL */
|
||||||
GST_DEBUG (0, "scheduler %p dispose %p %p %p",
|
GST_DEBUG ( "scheduler %p dispose %p %p %p",
|
||||||
object,
|
object,
|
||||||
sched->clock_providers,
|
sched->clock_providers,
|
||||||
sched->clock_receivers,
|
sched->clock_receivers,
|
||||||
|
@ -228,7 +228,7 @@ gst_scheduler_add_element (GstScheduler *sched, GstElement *element)
|
||||||
|
|
||||||
/* if it's already in this scheduler, don't bother doing anything */
|
/* if it's already in this scheduler, don't bother doing anything */
|
||||||
if (GST_ELEMENT_SCHED (element) == sched) {
|
if (GST_ELEMENT_SCHED (element) == sched) {
|
||||||
GST_DEBUG (GST_CAT_SCHEDULING, "element %s already in scheduler %p",
|
GST_CAT_DEBUG (GST_CAT_SCHEDULING, "element %s already in scheduler %p",
|
||||||
GST_ELEMENT_NAME (element), sched);
|
GST_ELEMENT_NAME (element), sched);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
@ -238,11 +238,11 @@ gst_scheduler_add_element (GstScheduler *sched, GstElement *element)
|
||||||
|
|
||||||
if (gst_element_provides_clock (element)) {
|
if (gst_element_provides_clock (element)) {
|
||||||
sched->clock_providers = g_list_prepend (sched->clock_providers, element);
|
sched->clock_providers = g_list_prepend (sched->clock_providers, element);
|
||||||
GST_DEBUG (GST_CAT_CLOCK, "added clock provider %s", GST_ELEMENT_NAME (element));
|
GST_CAT_DEBUG (GST_CAT_CLOCK, "added clock provider %s", GST_ELEMENT_NAME (element));
|
||||||
}
|
}
|
||||||
if (gst_element_requires_clock (element)) {
|
if (gst_element_requires_clock (element)) {
|
||||||
sched->clock_receivers = g_list_prepend (sched->clock_receivers, element);
|
sched->clock_receivers = g_list_prepend (sched->clock_receivers, element);
|
||||||
GST_DEBUG (GST_CAT_CLOCK, "added clock receiver %s", GST_ELEMENT_NAME (element));
|
GST_CAT_DEBUG (GST_CAT_CLOCK, "added clock receiver %s", GST_ELEMENT_NAME (element));
|
||||||
}
|
}
|
||||||
|
|
||||||
gst_element_set_scheduler (element, sched);
|
gst_element_set_scheduler (element, sched);
|
||||||
|
@ -307,7 +307,7 @@ gst_scheduler_state_transition (GstScheduler *sched, GstElement *element, gint t
|
||||||
if (clock)
|
if (clock)
|
||||||
gst_clock_reset (clock);
|
gst_clock_reset (clock);
|
||||||
|
|
||||||
GST_DEBUG (GST_CAT_CLOCK, "scheduler READY to PAUSED clock is %p (%s)", clock,
|
GST_CAT_DEBUG (GST_CAT_CLOCK, "scheduler READY to PAUSED clock is %p (%s)", clock,
|
||||||
(clock ? GST_OBJECT_NAME (clock) : "nil"));
|
(clock ? GST_OBJECT_NAME (clock) : "nil"));
|
||||||
|
|
||||||
gst_object_replace ((GstObject **)&sched->current_clock, (GstObject *)clock);
|
gst_object_replace ((GstObject **)&sched->current_clock, (GstObject *)clock);
|
||||||
|
@ -317,12 +317,12 @@ gst_scheduler_state_transition (GstScheduler *sched, GstElement *element, gint t
|
||||||
{
|
{
|
||||||
GstClock *clock = gst_scheduler_get_clock (sched);
|
GstClock *clock = gst_scheduler_get_clock (sched);
|
||||||
|
|
||||||
GST_DEBUG (GST_CAT_CLOCK, "scheduler PAUSED to PLAYING clock is %p (%s)", clock,
|
GST_CAT_DEBUG (GST_CAT_CLOCK, "scheduler PAUSED to PLAYING clock is %p (%s)", clock,
|
||||||
(clock ? GST_OBJECT_NAME (clock) : "nil"));
|
(clock ? GST_OBJECT_NAME (clock) : "nil"));
|
||||||
|
|
||||||
gst_scheduler_set_clock (sched, clock);
|
gst_scheduler_set_clock (sched, clock);
|
||||||
if (clock) {
|
if (clock) {
|
||||||
GST_DEBUG (GST_CAT_CLOCK, "enabling clock %p (%s)", clock,
|
GST_CAT_DEBUG (GST_CAT_CLOCK, "enabling clock %p (%s)", clock,
|
||||||
GST_OBJECT_NAME (clock));
|
GST_OBJECT_NAME (clock));
|
||||||
gst_clock_set_active (clock, TRUE);
|
gst_clock_set_active (clock, TRUE);
|
||||||
}
|
}
|
||||||
|
@ -330,7 +330,7 @@ gst_scheduler_state_transition (GstScheduler *sched, GstElement *element, gint t
|
||||||
}
|
}
|
||||||
case GST_STATE_PLAYING_TO_PAUSED:
|
case GST_STATE_PLAYING_TO_PAUSED:
|
||||||
if (sched->current_clock) {
|
if (sched->current_clock) {
|
||||||
GST_DEBUG (GST_CAT_CLOCK, "disabling clock %p (%s)", sched->current_clock,
|
GST_CAT_DEBUG (GST_CAT_CLOCK, "disabling clock %p (%s)", sched->current_clock,
|
||||||
GST_OBJECT_NAME (sched->current_clock));
|
GST_OBJECT_NAME (sched->current_clock));
|
||||||
gst_clock_set_active (sched->current_clock, FALSE);
|
gst_clock_set_active (sched->current_clock, FALSE);
|
||||||
}
|
}
|
||||||
|
@ -385,7 +385,7 @@ gst_scheduler_add_scheduler (GstScheduler *sched, GstScheduler *sched2)
|
||||||
g_return_if_fail (GST_IS_SCHEDULER (sched2));
|
g_return_if_fail (GST_IS_SCHEDULER (sched2));
|
||||||
g_return_if_fail (sched2->parent_sched == NULL);
|
g_return_if_fail (sched2->parent_sched == NULL);
|
||||||
|
|
||||||
GST_DEBUG (0,"gstscheduler: %p add scheduler %p", sched, sched2);
|
GST_DEBUG ("gstscheduler: %p add scheduler %p", sched, sched2);
|
||||||
|
|
||||||
gst_object_ref (GST_OBJECT (sched2));
|
gst_object_ref (GST_OBJECT (sched2));
|
||||||
gst_object_ref (GST_OBJECT (sched));
|
gst_object_ref (GST_OBJECT (sched));
|
||||||
|
@ -415,7 +415,7 @@ gst_scheduler_remove_scheduler (GstScheduler *sched, GstScheduler *sched2)
|
||||||
g_return_if_fail (GST_IS_SCHEDULER (sched2));
|
g_return_if_fail (GST_IS_SCHEDULER (sched2));
|
||||||
g_return_if_fail (sched2->parent_sched == sched);
|
g_return_if_fail (sched2->parent_sched == sched);
|
||||||
|
|
||||||
GST_DEBUG (0,"gstscheduler: %p remove scheduler %p", sched, sched2);
|
GST_DEBUG ("gstscheduler: %p remove scheduler %p", sched, sched2);
|
||||||
|
|
||||||
sclass = GST_SCHEDULER_GET_CLASS (sched);
|
sclass = GST_SCHEDULER_GET_CLASS (sched);
|
||||||
|
|
||||||
|
@ -561,7 +561,7 @@ gst_scheduler_get_clock (GstScheduler *sched)
|
||||||
if (GST_FLAG_IS_SET (sched, GST_SCHEDULER_FLAG_FIXED_CLOCK)) {
|
if (GST_FLAG_IS_SET (sched, GST_SCHEDULER_FLAG_FIXED_CLOCK)) {
|
||||||
clock = sched->clock;
|
clock = sched->clock;
|
||||||
|
|
||||||
GST_DEBUG (GST_CAT_CLOCK, "scheduler using fixed clock %p (%s)", clock,
|
GST_CAT_DEBUG (GST_CAT_CLOCK, "scheduler using fixed clock %p (%s)", clock,
|
||||||
(clock ? GST_OBJECT_NAME (clock) : "nil"));
|
(clock ? GST_OBJECT_NAME (clock) : "nil"));
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
|
@ -589,8 +589,8 @@ gst_scheduler_get_clock (GstScheduler *sched)
|
||||||
clock = gst_system_clock_obtain ();
|
clock = gst_system_clock_obtain ();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
GST_DEBUG (GST_CAT_CLOCK, "scheduler selected clock %p (%s)", clock,
|
GST_CAT_LOG_OBJECT (GST_CAT_CLOCK, sched, "scheduler selected clock %p (%s)", clock,
|
||||||
(clock ? GST_OBJECT_NAME (clock) : "nil"));
|
clock ? GST_STR_NULL (GST_OBJECT_NAME (clock)) : "-");
|
||||||
|
|
||||||
return clock;
|
return clock;
|
||||||
}
|
}
|
||||||
|
@ -614,7 +614,7 @@ gst_scheduler_use_clock (GstScheduler *sched, GstClock *clock)
|
||||||
|
|
||||||
gst_object_replace ((GstObject **)&sched->clock, (GstObject *)clock);
|
gst_object_replace ((GstObject **)&sched->clock, (GstObject *)clock);
|
||||||
|
|
||||||
GST_DEBUG (GST_CAT_CLOCK, "scheduler using fixed clock %p (%s)", clock,
|
GST_CAT_DEBUG (GST_CAT_CLOCK, "scheduler using fixed clock %p (%s)", clock,
|
||||||
(clock ? GST_OBJECT_NAME (clock) : "nil"));
|
(clock ? GST_OBJECT_NAME (clock) : "nil"));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -643,7 +643,7 @@ gst_scheduler_set_clock (GstScheduler *sched, GstClock *clock)
|
||||||
while (receivers) {
|
while (receivers) {
|
||||||
GstElement *element = GST_ELEMENT (receivers->data);
|
GstElement *element = GST_ELEMENT (receivers->data);
|
||||||
|
|
||||||
GST_DEBUG (GST_CAT_CLOCK, "scheduler setting clock %p (%s) on element %s", clock,
|
GST_CAT_DEBUG (GST_CAT_CLOCK, "scheduler setting clock %p (%s) on element %s", clock,
|
||||||
(clock ? GST_OBJECT_NAME (clock) : "nil"), GST_ELEMENT_NAME (element));
|
(clock ? GST_OBJECT_NAME (clock) : "nil"), GST_ELEMENT_NAME (element));
|
||||||
|
|
||||||
gst_element_set_clock (element, clock);
|
gst_element_set_clock (element, clock);
|
||||||
|
@ -652,7 +652,7 @@ gst_scheduler_set_clock (GstScheduler *sched, GstClock *clock)
|
||||||
while (schedulers) {
|
while (schedulers) {
|
||||||
GstScheduler *scheduler = GST_SCHEDULER (schedulers->data);
|
GstScheduler *scheduler = GST_SCHEDULER (schedulers->data);
|
||||||
|
|
||||||
GST_DEBUG (GST_CAT_CLOCK, "scheduler setting clock %p (%s) on scheduler %p", clock,
|
GST_CAT_DEBUG (GST_CAT_CLOCK, "scheduler setting clock %p (%s) on scheduler %p", clock,
|
||||||
(clock ? GST_OBJECT_NAME (clock) : "nil"), scheduler);
|
(clock ? GST_OBJECT_NAME (clock) : "nil"), scheduler);
|
||||||
gst_scheduler_set_clock (scheduler, clock);
|
gst_scheduler_set_clock (scheduler, clock);
|
||||||
schedulers = g_list_next (schedulers);
|
schedulers = g_list_next (schedulers);
|
||||||
|
@ -675,7 +675,7 @@ gst_scheduler_auto_clock (GstScheduler *sched)
|
||||||
|
|
||||||
gst_object_replace ((GstObject **)&sched->clock, NULL);
|
gst_object_replace ((GstObject **)&sched->clock, NULL);
|
||||||
|
|
||||||
GST_DEBUG (GST_CAT_CLOCK, "scheduler using automatic clock");
|
GST_CAT_DEBUG (GST_CAT_CLOCK, "scheduler using automatic clock");
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -871,7 +871,7 @@ gst_scheduler_factory_find (const gchar *name)
|
||||||
|
|
||||||
g_return_val_if_fail (name != NULL, NULL);
|
g_return_val_if_fail (name != NULL, NULL);
|
||||||
|
|
||||||
GST_DEBUG (0,"gstscheduler: find \"%s\"", name);
|
GST_DEBUG ("gstscheduler: find \"%s\"", name);
|
||||||
|
|
||||||
feature = gst_registry_pool_find_feature (name, GST_TYPE_SCHEDULER_FACTORY);
|
feature = gst_registry_pool_find_feature (name, GST_TYPE_SCHEDULER_FACTORY);
|
||||||
|
|
||||||
|
|
|
@ -23,7 +23,7 @@
|
||||||
#include <sys/time.h>
|
#include <sys/time.h>
|
||||||
|
|
||||||
#include "gst_private.h"
|
#include "gst_private.h"
|
||||||
#include "gstlog.h"
|
#include "gstinfo.h"
|
||||||
|
|
||||||
#include "gstsystemclock.h"
|
#include "gstsystemclock.h"
|
||||||
|
|
||||||
|
@ -178,15 +178,15 @@ gst_system_clock_wait (GstClock *clock, GstClockEntry *entry)
|
||||||
current = gst_clock_get_time (clock);
|
current = gst_clock_get_time (clock);
|
||||||
diff = GST_CLOCK_ENTRY_TIME (entry) - current;
|
diff = GST_CLOCK_ENTRY_TIME (entry) - current;
|
||||||
|
|
||||||
if (ABS (diff) > clock->max_diff) {
|
if (diff + clock->max_diff < 0) {
|
||||||
g_warning ("abnormal clock request diff: ABS(%" G_GINT64_FORMAT
|
g_warning ("clock is way behind: %" G_GINT64_FORMAT
|
||||||
") > %" G_GINT64_FORMAT, diff, clock->max_diff);
|
"s (max allowed is %" G_GINT64_FORMAT "s", -diff, clock->max_diff);
|
||||||
return GST_CLOCK_ENTRY_EARLY;
|
return GST_CLOCK_ENTRY_EARLY;
|
||||||
}
|
}
|
||||||
|
|
||||||
target = gst_system_clock_get_internal_time (clock) + diff;
|
target = gst_system_clock_get_internal_time (clock) + diff;
|
||||||
|
|
||||||
GST_DEBUG (GST_CAT_CLOCK, "real_target %" G_GUINT64_FORMAT
|
GST_CAT_DEBUG (GST_CAT_CLOCK, "real_target %" G_GUINT64_FORMAT
|
||||||
" target %" G_GUINT64_FORMAT
|
" target %" G_GUINT64_FORMAT
|
||||||
" now %" G_GUINT64_FORMAT,
|
" now %" G_GUINT64_FORMAT,
|
||||||
target, GST_CLOCK_ENTRY_TIME (entry), current);
|
target, GST_CLOCK_ENTRY_TIME (entry), current);
|
||||||
|
|
|
@ -21,6 +21,8 @@
|
||||||
* Boston, MA 02111-1307, USA.
|
* Boston, MA 02111-1307, USA.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
#include "gst_private.h"
|
||||||
|
|
||||||
#include "gstthread.h"
|
#include "gstthread.h"
|
||||||
#include "gstscheduler.h"
|
#include "gstscheduler.h"
|
||||||
#include "gstinfo.h"
|
#include "gstinfo.h"
|
||||||
|
@ -175,7 +177,7 @@ gst_thread_init (GstThread *thread)
|
||||||
{
|
{
|
||||||
GstScheduler *scheduler;
|
GstScheduler *scheduler;
|
||||||
|
|
||||||
GST_DEBUG (GST_CAT_THREAD, "initializing thread");
|
GST_CAT_DEBUG (GST_CAT_THREAD, "initializing thread");
|
||||||
|
|
||||||
/* threads are managing bins and iterate themselves */
|
/* threads are managing bins and iterate themselves */
|
||||||
/* CR1: the GstBin code checks these flags */
|
/* CR1: the GstBin code checks these flags */
|
||||||
|
@ -197,7 +199,7 @@ gst_thread_dispose (GObject *object)
|
||||||
{
|
{
|
||||||
GstThread *thread = GST_THREAD (object);
|
GstThread *thread = GST_THREAD (object);
|
||||||
|
|
||||||
GST_DEBUG (GST_CAT_REFCOUNTING, "GstThread: dispose");
|
GST_CAT_DEBUG (GST_CAT_REFCOUNTING, "GstThread: dispose");
|
||||||
|
|
||||||
G_OBJECT_CLASS (parent_class)->dispose (object);
|
G_OBJECT_CLASS (parent_class)->dispose (object);
|
||||||
|
|
||||||
|
@ -299,7 +301,7 @@ gst_thread_release_children_locks (GstThread *thread)
|
||||||
GList *pads;
|
GList *pads;
|
||||||
|
|
||||||
g_assert (element);
|
g_assert (element);
|
||||||
GST_DEBUG (GST_CAT_THREAD, "waking element \"%s\"", GST_ELEMENT_NAME (element));
|
GST_CAT_DEBUG (GST_CAT_THREAD, "waking element \"%s\"", GST_ELEMENT_NAME (element));
|
||||||
elements = g_list_next (elements);
|
elements = g_list_next (elements);
|
||||||
|
|
||||||
if (!gst_element_release_locks (element))
|
if (!gst_element_release_locks (element))
|
||||||
|
@ -324,8 +326,8 @@ gst_thread_release_children_locks (GstThread *thread)
|
||||||
continue; /* FIXME: deal with case where there's no peer */
|
continue; /* FIXME: deal with case where there's no peer */
|
||||||
|
|
||||||
if (GST_ELEMENT_SCHED (peerelement) != GST_ELEMENT_SCHED (thread)) {
|
if (GST_ELEMENT_SCHED (peerelement) != GST_ELEMENT_SCHED (thread)) {
|
||||||
GST_DEBUG (GST_CAT_THREAD, "element \"%s\" has pad cross sched boundary", GST_ELEMENT_NAME (element));
|
GST_CAT_DEBUG (GST_CAT_THREAD, "element \"%s\" has pad cross sched boundary", GST_ELEMENT_NAME (element));
|
||||||
GST_DEBUG (GST_CAT_THREAD, "waking element \"%s\"", GST_ELEMENT_NAME (peerelement));
|
GST_CAT_DEBUG (GST_CAT_THREAD, "waking element \"%s\"", GST_ELEMENT_NAME (peerelement));
|
||||||
if (!gst_element_release_locks (peerelement))
|
if (!gst_element_release_locks (peerelement))
|
||||||
g_warning ("element %s could not release locks", GST_ELEMENT_NAME (peerelement));
|
g_warning ("element %s could not release locks", GST_ELEMENT_NAME (peerelement));
|
||||||
}
|
}
|
||||||
|
@ -343,7 +345,7 @@ gst_thread_catch (GstThread *thread)
|
||||||
g_mutex_lock (thread->lock);
|
g_mutex_lock (thread->lock);
|
||||||
GST_FLAG_SET (thread, GST_THREAD_MUTEX_LOCKED);
|
GST_FLAG_SET (thread, GST_THREAD_MUTEX_LOCKED);
|
||||||
}
|
}
|
||||||
GST_DEBUG (GST_CAT_THREAD, "%s is catching itself", GST_ELEMENT_NAME (thread));
|
GST_CAT_DEBUG (GST_CAT_THREAD, "%s is catching itself", GST_ELEMENT_NAME (thread));
|
||||||
GST_FLAG_UNSET (thread, GST_THREAD_STATE_SPINNING);
|
GST_FLAG_UNSET (thread, GST_THREAD_STATE_SPINNING);
|
||||||
} else {
|
} else {
|
||||||
/* another thread is trying to catch us */
|
/* another thread is trying to catch us */
|
||||||
|
@ -351,7 +353,7 @@ gst_thread_catch (GstThread *thread)
|
||||||
wait = !GST_FLAG_IS_SET (thread, GST_THREAD_STATE_SPINNING);
|
wait = !GST_FLAG_IS_SET (thread, GST_THREAD_STATE_SPINNING);
|
||||||
while (!wait) {
|
while (!wait) {
|
||||||
GTimeVal tv;
|
GTimeVal tv;
|
||||||
GST_DEBUG (GST_CAT_THREAD, "catching %s...", GST_ELEMENT_NAME (thread));
|
GST_CAT_DEBUG (GST_CAT_THREAD, "catching %s...", GST_ELEMENT_NAME (thread));
|
||||||
GST_FLAG_UNSET (thread, GST_THREAD_STATE_SPINNING);
|
GST_FLAG_UNSET (thread, GST_THREAD_STATE_SPINNING);
|
||||||
g_cond_signal (thread->cond);
|
g_cond_signal (thread->cond);
|
||||||
gst_thread_release_children_locks (thread);
|
gst_thread_release_children_locks (thread);
|
||||||
|
@ -359,7 +361,7 @@ gst_thread_catch (GstThread *thread)
|
||||||
g_time_val_add (&tv, 1000); /* wait a millisecond to catch the thread */
|
g_time_val_add (&tv, 1000); /* wait a millisecond to catch the thread */
|
||||||
wait = g_cond_timed_wait (thread->cond, thread->lock, &tv);
|
wait = g_cond_timed_wait (thread->cond, thread->lock, &tv);
|
||||||
}
|
}
|
||||||
GST_DEBUG (GST_CAT_THREAD, "caught %s", GST_ELEMENT_NAME (thread));
|
GST_CAT_DEBUG (GST_CAT_THREAD, "caught %s", GST_ELEMENT_NAME (thread));
|
||||||
}
|
}
|
||||||
g_assert (!GST_FLAG_IS_SET (thread, GST_THREAD_STATE_SPINNING));
|
g_assert (!GST_FLAG_IS_SET (thread, GST_THREAD_STATE_SPINNING));
|
||||||
}
|
}
|
||||||
|
@ -385,7 +387,7 @@ gst_thread_change_state (GstElement *element)
|
||||||
|
|
||||||
thread = GST_THREAD (element);
|
thread = GST_THREAD (element);
|
||||||
|
|
||||||
GST_DEBUG (GST_CAT_STATES, "%s is changing state from %s to %s",
|
GST_CAT_DEBUG (GST_CAT_STATES, "%s is changing state from %s to %s",
|
||||||
GST_ELEMENT_NAME (element), gst_element_state_get_name (GST_STATE (element)),
|
GST_ELEMENT_NAME (element), gst_element_state_get_name (GST_STATE (element)),
|
||||||
gst_element_state_get_name (GST_STATE_PENDING (element)));
|
gst_element_state_get_name (GST_STATE_PENDING (element)));
|
||||||
|
|
||||||
|
@ -406,10 +408,10 @@ gst_thread_change_state (GstElement *element)
|
||||||
thread, STACK_SIZE, FALSE, TRUE, thread->priority,
|
thread, STACK_SIZE, FALSE, TRUE, thread->priority,
|
||||||
NULL);
|
NULL);
|
||||||
if (!thread->thread_id){
|
if (!thread->thread_id){
|
||||||
GST_DEBUG (GST_CAT_THREAD, "g_thread_create_full for %sfailed", GST_ELEMENT_NAME (element));
|
GST_CAT_DEBUG (GST_CAT_THREAD, "g_thread_create_full for %sfailed", GST_ELEMENT_NAME (element));
|
||||||
goto error_out;
|
goto error_out;
|
||||||
}
|
}
|
||||||
GST_DEBUG (GST_CAT_THREAD, "GThread created");
|
GST_CAT_DEBUG (GST_CAT_THREAD, "GThread created");
|
||||||
|
|
||||||
/* wait for it to 'spin up' */
|
/* wait for it to 'spin up' */
|
||||||
g_cond_wait (thread->cond, thread->lock);
|
g_cond_wait (thread->cond, thread->lock);
|
||||||
|
@ -443,7 +445,7 @@ gst_thread_change_state (GstElement *element)
|
||||||
case GST_STATE_READY_TO_NULL:
|
case GST_STATE_READY_TO_NULL:
|
||||||
/* we can't join the threads here, because this could have been triggered
|
/* we can't join the threads here, because this could have been triggered
|
||||||
by ourself (ouch) */
|
by ourself (ouch) */
|
||||||
GST_DEBUG (GST_CAT_THREAD, "destroying GThread %p", thread->thread_id);
|
GST_CAT_DEBUG (GST_CAT_THREAD, "destroying GThread %p", thread->thread_id);
|
||||||
GST_FLAG_SET (thread, GST_THREAD_STATE_REAPING);
|
GST_FLAG_SET (thread, GST_THREAD_STATE_REAPING);
|
||||||
thread->thread_id = NULL;
|
thread->thread_id = NULL;
|
||||||
if (thread == gst_thread_get_current()) {
|
if (thread == gst_thread_get_current()) {
|
||||||
|
@ -454,7 +456,7 @@ gst_thread_change_state (GstElement *element)
|
||||||
/* unlock and signal - we are out */
|
/* unlock and signal - we are out */
|
||||||
gst_thread_release (thread);
|
gst_thread_release (thread);
|
||||||
|
|
||||||
GST_INFO (GST_CAT_THREAD, "gstthread: thread \"%s\" is stopped",
|
GST_CAT_INFO (GST_CAT_THREAD, "gstthread: thread \"%s\" is stopped",
|
||||||
GST_ELEMENT_NAME (thread));
|
GST_ELEMENT_NAME (thread));
|
||||||
|
|
||||||
g_signal_emit (G_OBJECT (thread), gst_thread_signals[SHUTDOWN], 0);
|
g_signal_emit (G_OBJECT (thread), gst_thread_signals[SHUTDOWN], 0);
|
||||||
|
@ -467,8 +469,8 @@ gst_thread_change_state (GstElement *element)
|
||||||
/* it should be dead now */
|
/* it should be dead now */
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
GST_DEBUG_ELEMENT (GST_CAT_THREAD, element, "UNHANDLED STATE CHANGE! %x",
|
GST_CAT_DEBUG (GST_CAT_THREAD, "[%s]: UNHANDLED STATE CHANGE! %x",
|
||||||
GST_STATE_TRANSITION (element));
|
GST_ELEMENT_NAME (element), GST_STATE_TRANSITION (element));
|
||||||
g_assert_not_reached ();
|
g_assert_not_reached ();
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
@ -483,7 +485,7 @@ gst_thread_change_state (GstElement *element)
|
||||||
return ret;
|
return ret;
|
||||||
|
|
||||||
error_out:
|
error_out:
|
||||||
GST_DEBUG (GST_CAT_STATES, "changing state from %s to %s failed for %s",
|
GST_CAT_DEBUG (GST_CAT_STATES, "changing state from %s to %s failed for %s",
|
||||||
gst_element_state_get_name (GST_STATE (element)),
|
gst_element_state_get_name (GST_STATE (element)),
|
||||||
gst_element_state_get_name (GST_STATE_PENDING (element)),
|
gst_element_state_get_name (GST_STATE_PENDING (element)),
|
||||||
GST_ELEMENT_NAME (element));
|
GST_ELEMENT_NAME (element));
|
||||||
|
@ -498,7 +500,7 @@ static void
|
||||||
gst_thread_child_state_change (GstBin *bin, GstElementState oldstate,
|
gst_thread_child_state_change (GstBin *bin, GstElementState oldstate,
|
||||||
GstElementState newstate, GstElement *element)
|
GstElementState newstate, GstElement *element)
|
||||||
{
|
{
|
||||||
GST_DEBUG (GST_CAT_THREAD, "%s (from thread %s) child %s changed state from %s to %s",
|
GST_CAT_DEBUG (GST_CAT_THREAD, "%s (from thread %s) child %s changed state from %s to %s",
|
||||||
GST_ELEMENT_NAME (bin),
|
GST_ELEMENT_NAME (bin),
|
||||||
gst_thread_get_current() ? GST_ELEMENT_NAME (gst_thread_get_current()) : "(none)",
|
gst_thread_get_current() ? GST_ELEMENT_NAME (gst_thread_get_current()) : "(none)",
|
||||||
GST_ELEMENT_NAME (element), gst_element_state_get_name (oldstate),
|
GST_ELEMENT_NAME (element), gst_element_state_get_name (oldstate),
|
||||||
|
@ -526,7 +528,7 @@ gst_thread_main_loop (void *arg)
|
||||||
|
|
||||||
thread = GST_THREAD (arg);
|
thread = GST_THREAD (arg);
|
||||||
g_mutex_lock (thread->lock);
|
g_mutex_lock (thread->lock);
|
||||||
GST_DEBUG (GST_CAT_THREAD, "Thread %s started main loop", GST_ELEMENT_NAME (thread));
|
GST_CAT_DEBUG (GST_CAT_THREAD, "Thread %s started main loop", GST_ELEMENT_NAME (thread));
|
||||||
|
|
||||||
/* initialize gst_thread_current */
|
/* initialize gst_thread_current */
|
||||||
g_private_set (gst_thread_current, thread);
|
g_private_set (gst_thread_current, thread);
|
||||||
|
@ -540,7 +542,7 @@ gst_thread_main_loop (void *arg)
|
||||||
if (GST_STATE (thread) == GST_STATE_PLAYING) {
|
if (GST_STATE (thread) == GST_STATE_PLAYING) {
|
||||||
GST_FLAG_SET (thread, GST_THREAD_STATE_SPINNING);
|
GST_FLAG_SET (thread, GST_THREAD_STATE_SPINNING);
|
||||||
status = TRUE;
|
status = TRUE;
|
||||||
GST_DEBUG (GST_CAT_THREAD, "%s starts iterating", GST_ELEMENT_NAME (thread));
|
GST_CAT_DEBUG (GST_CAT_THREAD, "%s starts iterating", GST_ELEMENT_NAME (thread));
|
||||||
while (status && GST_FLAG_IS_SET (thread, GST_THREAD_STATE_SPINNING)) {
|
while (status && GST_FLAG_IS_SET (thread, GST_THREAD_STATE_SPINNING)) {
|
||||||
g_mutex_unlock (thread->lock);
|
g_mutex_unlock (thread->lock);
|
||||||
status = gst_bin_iterate (GST_BIN (thread));
|
status = gst_bin_iterate (GST_BIN (thread));
|
||||||
|
@ -554,7 +556,7 @@ gst_thread_main_loop (void *arg)
|
||||||
}
|
}
|
||||||
if (GST_FLAG_IS_SET (thread, GST_THREAD_STATE_REAPING))
|
if (GST_FLAG_IS_SET (thread, GST_THREAD_STATE_REAPING))
|
||||||
break;
|
break;
|
||||||
GST_DEBUG (GST_CAT_THREAD, "%s was caught", GST_ELEMENT_NAME (thread));
|
GST_CAT_DEBUG (GST_CAT_THREAD, "%s was caught", GST_ELEMENT_NAME (thread));
|
||||||
g_cond_signal (thread->cond);
|
g_cond_signal (thread->cond);
|
||||||
g_cond_wait (thread->cond, thread->lock);
|
g_cond_wait (thread->cond, thread->lock);
|
||||||
}
|
}
|
||||||
|
@ -570,7 +572,7 @@ gst_thread_main_loop (void *arg)
|
||||||
g_cond_signal (thread->cond);
|
g_cond_signal (thread->cond);
|
||||||
g_mutex_unlock (thread->lock);
|
g_mutex_unlock (thread->lock);
|
||||||
|
|
||||||
GST_INFO (GST_CAT_THREAD, "gstthread: thread \"%s\" is stopped",
|
GST_CAT_INFO (GST_CAT_THREAD, "gstthread: thread \"%s\" is stopped",
|
||||||
GST_ELEMENT_NAME (thread));
|
GST_ELEMENT_NAME (thread));
|
||||||
|
|
||||||
return NULL;
|
return NULL;
|
||||||
|
@ -590,7 +592,7 @@ static void
|
||||||
gst_thread_restore_thyself (GstObject *object,
|
gst_thread_restore_thyself (GstObject *object,
|
||||||
xmlNodePtr self)
|
xmlNodePtr self)
|
||||||
{
|
{
|
||||||
GST_DEBUG (GST_CAT_THREAD,"gstthread: restore");
|
GST_CAT_DEBUG (GST_CAT_THREAD,"gstthread: restore");
|
||||||
|
|
||||||
if (GST_OBJECT_CLASS (parent_class)->restore_thyself)
|
if (GST_OBJECT_CLASS (parent_class)->restore_thyself)
|
||||||
GST_OBJECT_CLASS (parent_class)->restore_thyself (object, self);
|
GST_OBJECT_CLASS (parent_class)->restore_thyself (object, self);
|
||||||
|
|
|
@ -32,7 +32,7 @@
|
||||||
#include "gsttype.h"
|
#include "gsttype.h"
|
||||||
#include "gstregistrypool.h"
|
#include "gstregistrypool.h"
|
||||||
#include "gstobject.h"
|
#include "gstobject.h"
|
||||||
#include "gstlog.h"
|
#include "gstinfo.h"
|
||||||
|
|
||||||
|
|
||||||
/* global list of registered types */
|
/* global list of registered types */
|
||||||
|
@ -146,7 +146,7 @@ gst_type_register (GstTypeFactory *factory)
|
||||||
|
|
||||||
g_return_val_if_fail (factory != NULL, 0);
|
g_return_val_if_fail (factory != NULL, 0);
|
||||||
|
|
||||||
/* GST_INFO (GST_CAT_TYPES,"type register %s", factory->mime); */
|
/* GST_CAT_INFO (GST_CAT_TYPES,"type register %s", factory->mime); */
|
||||||
id = gst_type_find_by_mime (factory->mime);
|
id = gst_type_find_by_mime (factory->mime);
|
||||||
|
|
||||||
if (!id) {
|
if (!id) {
|
||||||
|
@ -168,7 +168,7 @@ gst_type_register (GstTypeFactory *factory)
|
||||||
|
|
||||||
/* if there is no existing typefind function, try to use new one */
|
/* if there is no existing typefind function, try to use new one */
|
||||||
}
|
}
|
||||||
GST_DEBUG (GST_CAT_TYPES,"gsttype: %s(%p) gave new mime type '%s', id %d",
|
GST_CAT_DEBUG (GST_CAT_TYPES,"gsttype: %s(%p) gave new mime type '%s', id %d",
|
||||||
GST_OBJECT_NAME (factory), factory, type->mime, type->id);
|
GST_OBJECT_NAME (factory), factory, type->mime, type->id);
|
||||||
type->factories = g_slist_prepend (type->factories, factory);
|
type->factories = g_slist_prepend (type->factories, factory);
|
||||||
|
|
||||||
|
@ -186,12 +186,12 @@ gst_type_find_by_mime_func (const gchar *mime)
|
||||||
g_return_val_if_fail (mime != NULL, 0);
|
g_return_val_if_fail (mime != NULL, 0);
|
||||||
|
|
||||||
walk = _gst_types;
|
walk = _gst_types;
|
||||||
/* GST_DEBUG (GST_CAT_TYPES,"searching for '%s'",mime); */
|
/* GST_CAT_DEBUG (GST_CAT_TYPES,"searching for '%s'",mime); */
|
||||||
mimelen = strlen (mime);
|
mimelen = strlen (mime);
|
||||||
while (walk) {
|
while (walk) {
|
||||||
type = (GstType *)walk->data;
|
type = (GstType *)walk->data;
|
||||||
search = type->mime;
|
search = type->mime;
|
||||||
/* GST_DEBUG (GST_CAT_TYPES,"checking against '%s'",search); */
|
/* GST_CAT_DEBUG (GST_CAT_TYPES,"checking against '%s'",search); */
|
||||||
typelen = strlen (search);
|
typelen = strlen (search);
|
||||||
while ((search - type->mime) < typelen) {
|
while ((search - type->mime) < typelen) {
|
||||||
found = strstr (search, mime);
|
found = strstr (search, mime);
|
||||||
|
@ -321,7 +321,7 @@ gst_type_type_find_dummy (GstBuffer *buffer, gpointer priv)
|
||||||
GstCaps *res = NULL;
|
GstCaps *res = NULL;
|
||||||
GstTypeFactory *factory = (GstTypeFactory *)priv;
|
GstTypeFactory *factory = (GstTypeFactory *)priv;
|
||||||
|
|
||||||
GST_DEBUG (GST_CAT_TYPES,"gsttype: need to load typefind function for %s", factory->mime);
|
GST_CAT_DEBUG (GST_CAT_TYPES,"gsttype: need to load typefind function for %s", factory->mime);
|
||||||
|
|
||||||
if (gst_plugin_feature_ensure_loaded (GST_PLUGIN_FEATURE (factory))) {
|
if (gst_plugin_feature_ensure_loaded (GST_PLUGIN_FEATURE (factory))) {
|
||||||
if (factory->typefindfunc == gst_type_type_find_dummy) {
|
if (factory->typefindfunc == gst_type_type_find_dummy) {
|
||||||
|
|
|
@ -23,7 +23,7 @@
|
||||||
|
|
||||||
#include "gst_private.h"
|
#include "gst_private.h"
|
||||||
#include "gsttype.h"
|
#include "gsttype.h"
|
||||||
#include "gstlog.h"
|
#include "gstinfo.h"
|
||||||
#include "gsttypefind.h"
|
#include "gsttypefind.h"
|
||||||
|
|
||||||
#define DEFAULT_MAX_BUFFERS 1
|
#define DEFAULT_MAX_BUFFERS 1
|
||||||
|
@ -190,7 +190,7 @@ gst_type_find_chain (GstPad *pad, GstBuffer *buf)
|
||||||
|
|
||||||
typefind = GST_TYPE_FIND (GST_OBJECT_PARENT (pad));
|
typefind = GST_TYPE_FIND (GST_OBJECT_PARENT (pad));
|
||||||
|
|
||||||
GST_DEBUG (0,"got buffer of %d bytes in '%s'",
|
GST_DEBUG ("got buffer of %d bytes in '%s'",
|
||||||
GST_BUFFER_SIZE (buf), GST_OBJECT_NAME (typefind));
|
GST_BUFFER_SIZE (buf), GST_OBJECT_NAME (typefind));
|
||||||
|
|
||||||
type_list = gst_type_get_list ();
|
type_list = gst_type_get_list ();
|
||||||
|
@ -206,10 +206,10 @@ gst_type_find_chain (GstPad *pad, GstBuffer *buf)
|
||||||
GstTypeFindFunc typefindfunc = (GstTypeFindFunc)factory->typefindfunc;
|
GstTypeFindFunc typefindfunc = (GstTypeFindFunc)factory->typefindfunc;
|
||||||
GstCaps *caps;
|
GstCaps *caps;
|
||||||
|
|
||||||
GST_DEBUG (GST_CAT_TYPES, "try type (%p) :%d \"%s\" %p",
|
GST_CAT_DEBUG (GST_CAT_TYPES, "try type (%p) :%d \"%s\" %p",
|
||||||
factory, type->id, type->mime, typefindfunc);
|
factory, type->id, type->mime, typefindfunc);
|
||||||
if (typefindfunc && (caps = typefindfunc (buf, factory))) {
|
if (typefindfunc && (caps = typefindfunc (buf, factory))) {
|
||||||
GST_DEBUG (GST_CAT_TYPES, "found type: %d \"%s\" \"%s\"",
|
GST_CAT_DEBUG (GST_CAT_TYPES, "found type: %d \"%s\" \"%s\"",
|
||||||
caps->id, type->mime, gst_caps_get_name (caps));
|
caps->id, type->mime, gst_caps_get_name (caps));
|
||||||
typefind->caps = caps;
|
typefind->caps = caps;
|
||||||
|
|
||||||
|
|
|
@ -24,7 +24,7 @@
|
||||||
|
|
||||||
#include "gsturi.h"
|
#include "gsturi.h"
|
||||||
#include "gstregistrypool.h"
|
#include "gstregistrypool.h"
|
||||||
#include "gstlog.h"
|
#include "gstinfo.h"
|
||||||
|
|
||||||
static void gst_uri_handler_class_init (GstURIHandlerClass *klass);
|
static void gst_uri_handler_class_init (GstURIHandlerClass *klass);
|
||||||
static void gst_uri_handler_init (GstURIHandler *factory);
|
static void gst_uri_handler_init (GstURIHandler *factory);
|
||||||
|
|
|
@ -23,7 +23,7 @@
|
||||||
#include "gst_private.h"
|
#include "gst_private.h"
|
||||||
|
|
||||||
#include "gsturi.h"
|
#include "gsturi.h"
|
||||||
#include "gstlog.h"
|
#include "gstinfo.h"
|
||||||
|
|
||||||
GType
|
GType
|
||||||
gst_uri_get_uri_type (void)
|
gst_uri_get_uri_type (void)
|
||||||
|
|
|
@ -27,7 +27,7 @@
|
||||||
#include "gst_private.h"
|
#include "gst_private.h"
|
||||||
#include "gstutils.h"
|
#include "gstutils.h"
|
||||||
#include "gsturitype.h"
|
#include "gsturitype.h"
|
||||||
#include "gstlog.h"
|
#include "gstinfo.h"
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* gst_util_dump_mem:
|
* gst_util_dump_mem:
|
||||||
|
@ -82,7 +82,7 @@ gst_util_set_value_from_string(GValue *value, const gchar *value_str)
|
||||||
g_return_if_fail(value != NULL);
|
g_return_if_fail(value != NULL);
|
||||||
g_return_if_fail(value_str != NULL);
|
g_return_if_fail(value_str != NULL);
|
||||||
|
|
||||||
GST_DEBUG(GST_CAT_PARAMS, "parsing '%s' to type %s", value_str, g_type_name(G_VALUE_TYPE(value)));
|
GST_CAT_DEBUG (GST_CAT_PARAMS, "parsing '%s' to type %s", value_str, g_type_name(G_VALUE_TYPE(value)));
|
||||||
|
|
||||||
switch (G_VALUE_TYPE(value)) {
|
switch (G_VALUE_TYPE(value)) {
|
||||||
case G_TYPE_STRING:
|
case G_TYPE_STRING:
|
||||||
|
@ -169,7 +169,7 @@ gst_util_set_object_arg (GObject * object, const gchar * name, const gchar * val
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
GST_DEBUG (0, "paramspec->flags is %d, paramspec->value_type is %d",
|
GST_DEBUG ( "paramspec->flags is %d, paramspec->value_type is %d",
|
||||||
paramspec->flags, (gint) paramspec->value_type);
|
paramspec->flags, (gint) paramspec->value_type);
|
||||||
|
|
||||||
if (paramspec->flags & G_PARAM_WRITABLE) {
|
if (paramspec->flags & G_PARAM_WRITABLE) {
|
||||||
|
|
|
@ -24,9 +24,15 @@
|
||||||
#ifndef __GST_VERSION_H__
|
#ifndef __GST_VERSION_H__
|
||||||
#define __GST_VERSION_H__
|
#define __GST_VERSION_H__
|
||||||
|
|
||||||
#define GST_VERSION_MAJOR @GST_VERSION_MAJOR@
|
/**
|
||||||
#define GST_VERSION_MINOR @GST_VERSION_MINOR@
|
* Use these only when you want to know what GStreamer version your stuff was
|
||||||
#define GST_VERSION_MICRO @GST_VERSION_MICRO@
|
* compiled against.
|
||||||
|
* Use the #gst_version function if you want to know which versiuon of
|
||||||
|
* GStreamer you are currently linked against.
|
||||||
|
*/
|
||||||
|
#define GST_VERSION_MAJOR (@GST_VERSION_MAJOR@)
|
||||||
|
#define GST_VERSION_MINOR (@GST_VERSION_MINOR@)
|
||||||
|
#define GST_VERSION_MICRO (@GST_VERSION_MICRO@)
|
||||||
|
|
||||||
void gst_version (guint *major, guint *minor, guint *micro);
|
void gst_version (guint *major, guint *minor, guint *micro);
|
||||||
|
|
||||||
|
|
|
@ -23,7 +23,7 @@
|
||||||
#include "gst_private.h"
|
#include "gst_private.h"
|
||||||
|
|
||||||
#include "gstxml.h"
|
#include "gstxml.h"
|
||||||
#include "gstlog.h"
|
#include "gstinfo.h"
|
||||||
#include "gstbin.h"
|
#include "gstbin.h"
|
||||||
|
|
||||||
enum {
|
enum {
|
||||||
|
@ -346,14 +346,14 @@ gst_xml_get_element (GstXML *xml, const guchar *name)
|
||||||
g_return_val_if_fail(xml != NULL, NULL);
|
g_return_val_if_fail(xml != NULL, NULL);
|
||||||
g_return_val_if_fail(name != NULL, NULL);
|
g_return_val_if_fail(name != NULL, NULL);
|
||||||
|
|
||||||
GST_DEBUG (0,"gstxml: getting element \"%s\"", name);
|
GST_DEBUG ("gstxml: getting element \"%s\"", name);
|
||||||
|
|
||||||
topelements = gst_xml_get_topelements (xml);
|
topelements = gst_xml_get_topelements (xml);
|
||||||
|
|
||||||
while (topelements) {
|
while (topelements) {
|
||||||
GstElement *top = GST_ELEMENT (topelements->data);
|
GstElement *top = GST_ELEMENT (topelements->data);
|
||||||
|
|
||||||
GST_DEBUG (0,"gstxml: getting element \"%s\"", name);
|
GST_DEBUG ("gstxml: getting element \"%s\"", name);
|
||||||
if (!strcmp (GST_ELEMENT_NAME (top), name)) {
|
if (!strcmp (GST_ELEMENT_NAME (top), name)) {
|
||||||
return top;
|
return top;
|
||||||
}
|
}
|
||||||
|
@ -399,7 +399,7 @@ gst_xml_make_element (xmlNodePtr cur, GstObject *parent)
|
||||||
g_return_val_if_fail (name != NULL, NULL);
|
g_return_val_if_fail (name != NULL, NULL);
|
||||||
g_return_val_if_fail (type != NULL, NULL);
|
g_return_val_if_fail (type != NULL, NULL);
|
||||||
|
|
||||||
GST_INFO (GST_CAT_XML,"loading \"%s\" of type \"%s\"", name, type);
|
GST_CAT_INFO (GST_CAT_XML,"loading \"%s\" of type \"%s\"", name, type);
|
||||||
|
|
||||||
element = gst_element_factory_make (type, name);
|
element = gst_element_factory_make (type, name);
|
||||||
|
|
||||||
|
|
|
@ -17,16 +17,14 @@
|
||||||
* Boston, MA 02111-1307, USA.
|
* Boston, MA 02111-1307, USA.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#include <gst/gst_private.h>
|
#include <gst/gst.h>
|
||||||
#include <gst/gstversion.h>
|
|
||||||
#include <gst/gstplugin.h>
|
|
||||||
#include <gst/gstindex.h>
|
|
||||||
|
|
||||||
#include <unistd.h>
|
#include <unistd.h>
|
||||||
#include <sys/mman.h>
|
#include <sys/mman.h>
|
||||||
#include <sys/stat.h>
|
#include <sys/stat.h>
|
||||||
#include <errno.h>
|
#include <errno.h>
|
||||||
#include <fcntl.h>
|
#include <fcntl.h>
|
||||||
|
#include <string.h>
|
||||||
|
|
||||||
#define GST_TYPE_FILE_INDEX \
|
#define GST_TYPE_FILE_INDEX \
|
||||||
(gst_file_index_get_type ())
|
(gst_file_index_get_type ())
|
||||||
|
@ -193,7 +191,7 @@ gst_file_index_class_init (GstFileIndexClass *klass)
|
||||||
static void
|
static void
|
||||||
gst_file_index_init (GstFileIndex *index)
|
gst_file_index_init (GstFileIndex *index)
|
||||||
{
|
{
|
||||||
GST_DEBUG(0, "created new file index");
|
GST_DEBUG ( "created new file index");
|
||||||
|
|
||||||
index->id_index = g_hash_table_new (g_int_hash, g_int_equal);
|
index->id_index = g_hash_table_new (g_int_hash, g_int_equal);
|
||||||
}
|
}
|
||||||
|
@ -789,11 +787,7 @@ show_entry (GstIndexEntry *entry)
|
||||||
static void
|
static void
|
||||||
gst_file_index_add_entry (GstIndex *index, GstIndexEntry *entry)
|
gst_file_index_add_entry (GstIndex *index, GstIndexEntry *entry)
|
||||||
{
|
{
|
||||||
GstFileIndex *fileindex = GST_FILE_INDEX (index);
|
GST_LOG_OBJECT (index, "adding this entry");
|
||||||
|
|
||||||
GST_DEBUG (0, "adding entry %p\n", fileindex);
|
|
||||||
|
|
||||||
//show_entry (entry);
|
|
||||||
|
|
||||||
switch (entry->type){
|
switch (entry->type){
|
||||||
case GST_INDEX_ENTRY_ID:
|
case GST_INDEX_ENTRY_ID:
|
||||||
|
|
|
@ -17,10 +17,7 @@
|
||||||
* Boston, MA 02111-1307, USA.
|
* Boston, MA 02111-1307, USA.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#include <gst/gst_private.h>
|
#include <gst/gst.h>
|
||||||
#include <gst/gstversion.h>
|
|
||||||
#include <gst/gstplugin.h>
|
|
||||||
#include <gst/gstindex.h>
|
|
||||||
|
|
||||||
#define GST_TYPE_MEM_INDEX \
|
#define GST_TYPE_MEM_INDEX \
|
||||||
(gst_index_get_type ())
|
(gst_index_get_type ())
|
||||||
|
@ -158,7 +155,7 @@ gst_mem_index_class_init (GstMemIndexClass *klass)
|
||||||
static void
|
static void
|
||||||
gst_mem_index_init (GstMemIndex *index)
|
gst_mem_index_init (GstMemIndex *index)
|
||||||
{
|
{
|
||||||
GST_DEBUG(0, "created new mem index");
|
GST_DEBUG ( "created new mem index");
|
||||||
|
|
||||||
index->associations = NULL;
|
index->associations = NULL;
|
||||||
index->id_index = g_hash_table_new (g_int_hash, g_int_equal);
|
index->id_index = g_hash_table_new (g_int_hash, g_int_equal);
|
||||||
|
@ -260,9 +257,7 @@ gst_mem_index_add_format (GstIndex *index, GstIndexEntry *entry)
|
||||||
static void
|
static void
|
||||||
gst_mem_index_add_entry (GstIndex *index, GstIndexEntry *entry)
|
gst_mem_index_add_entry (GstIndex *index, GstIndexEntry *entry)
|
||||||
{
|
{
|
||||||
GstMemIndex *memindex = GST_MEM_INDEX (index);
|
GST_LOG_OBJECT (index, "added this entry");
|
||||||
|
|
||||||
GST_DEBUG (0, "adding entry %p\n", memindex);
|
|
||||||
|
|
||||||
switch (entry->type){
|
switch (entry->type){
|
||||||
case GST_INDEX_ENTRY_ID:
|
case GST_INDEX_ENTRY_ID:
|
||||||
|
|
|
@ -4,14 +4,13 @@
|
||||||
#include <stdio.h>
|
#include <stdio.h>
|
||||||
#include <string.h>
|
#include <string.h>
|
||||||
#include <stdlib.h>
|
#include <stdlib.h>
|
||||||
|
|
||||||
|
#include "../gst_private.h"
|
||||||
|
|
||||||
#include "../gstparse.h"
|
#include "../gstparse.h"
|
||||||
#include "../gstinfo.h"
|
#include "../gstinfo.h"
|
||||||
#include "types.h"
|
#include "types.h"
|
||||||
|
|
||||||
#ifdef HAVE_CONFIG_H
|
|
||||||
#include <config.h>
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#define YYERROR_VERBOSE 1
|
#define YYERROR_VERBOSE 1
|
||||||
#define YYPARSE_PARAM graph
|
#define YYPARSE_PARAM graph
|
||||||
|
|
||||||
|
@ -102,11 +101,11 @@ typedef struct {
|
||||||
# define YYDEBUG 1
|
# define YYDEBUG 1
|
||||||
/* bison 1.35 calls this macro with side effects, we need to make sure the
|
/* bison 1.35 calls this macro with side effects, we need to make sure the
|
||||||
side effects work - crappy bison
|
side effects work - crappy bison
|
||||||
# define YYFPRINTF(a, ...) GST_DEBUG (GST_CAT_PIPELINE, __VA_ARGS__)
|
# define YYFPRINTF(a, ...) GST_CAT_DEBUG (GST_CAT_PIPELINE, __VA_ARGS__)
|
||||||
*/
|
*/
|
||||||
# define YYFPRINTF(a, ...) G_STMT_START{ \
|
# define YYFPRINTF(a, ...) G_STMT_START{ \
|
||||||
gchar *temp = g_strdup_printf (__VA_ARGS__); \
|
gchar *temp = g_strdup_printf (__VA_ARGS__); \
|
||||||
GST_DEBUG (GST_CAT_PIPELINE, temp); \
|
GST_CAT_DEBUG (GST_CAT_PIPELINE, temp); \
|
||||||
g_free (temp); \
|
g_free (temp); \
|
||||||
}G_STMT_END
|
}G_STMT_END
|
||||||
#endif
|
#endif
|
||||||
|
@ -127,11 +126,11 @@ typedef struct {
|
||||||
# define YYDEBUG 1
|
# define YYDEBUG 1
|
||||||
/* bison 1.35 calls this macro with side effects, we need to make sure the
|
/* bison 1.35 calls this macro with side effects, we need to make sure the
|
||||||
side effects work - crappy bison
|
side effects work - crappy bison
|
||||||
# define YYFPRINTF(a, args...) GST_DEBUG (GST_CAT_PIPELINE, ## args )
|
# define YYFPRINTF(a, args...) GST_CAT_DEBUG (GST_CAT_PIPELINE, ## args )
|
||||||
*/
|
*/
|
||||||
# define YYFPRINTF(a, args...) G_STMT_START{ \
|
# define YYFPRINTF(a, args...) G_STMT_START{ \
|
||||||
gchar *temp = g_strdup_printf ( ## args ); \
|
gchar *temp = g_strdup_printf ( ## args ); \
|
||||||
GST_DEBUG (GST_CAT_PIPELINE, temp); \
|
GST_CAT_DEBUG (GST_CAT_PIPELINE, temp); \
|
||||||
g_free (temp); \
|
g_free (temp); \
|
||||||
}G_STMT_END
|
}G_STMT_END
|
||||||
#endif
|
#endif
|
||||||
|
@ -400,13 +399,13 @@ gst_parse_found_pad (GstElement *src, GstPad *pad, gpointer data)
|
||||||
{
|
{
|
||||||
DelayedLink *link = (DelayedLink *) data;
|
DelayedLink *link = (DelayedLink *) data;
|
||||||
|
|
||||||
GST_INFO (GST_CAT_PIPELINE, "trying delayed linking %s:%s to %s:%s",
|
GST_CAT_INFO (GST_CAT_PIPELINE, "trying delayed linking %s:%s to %s:%s",
|
||||||
GST_ELEMENT_NAME (src), link->src_pad,
|
GST_ELEMENT_NAME (src), link->src_pad,
|
||||||
GST_ELEMENT_NAME (link->sink), link->sink_pad);
|
GST_ELEMENT_NAME (link->sink), link->sink_pad);
|
||||||
|
|
||||||
if (gst_element_link_pads_filtered (src, link->src_pad, link->sink, link->sink_pad, link->caps)) {
|
if (gst_element_link_pads_filtered (src, link->src_pad, link->sink, link->sink_pad, link->caps)) {
|
||||||
/* do this here, we don't want to get any problems later on when unlocking states */
|
/* do this here, we don't want to get any problems later on when unlocking states */
|
||||||
GST_DEBUG (GST_CAT_PIPELINE, "delayed linking %s:%s to %s:%s worked",
|
GST_CAT_DEBUG (GST_CAT_PIPELINE, "delayed linking %s:%s to %s:%s worked",
|
||||||
GST_ELEMENT_NAME (src), link->src_pad,
|
GST_ELEMENT_NAME (src), link->src_pad,
|
||||||
GST_ELEMENT_NAME (link->sink), link->sink_pad);
|
GST_ELEMENT_NAME (link->sink), link->sink_pad);
|
||||||
g_signal_handler_disconnect (src, link->signal_id);
|
g_signal_handler_disconnect (src, link->signal_id);
|
||||||
|
@ -433,7 +432,7 @@ gst_parse_perform_delayed_link (GstElement *src, const gchar *src_pad,
|
||||||
|
|
||||||
/* TODO: maybe we should check if src_pad matches this template's names */
|
/* TODO: maybe we should check if src_pad matches this template's names */
|
||||||
|
|
||||||
GST_DEBUG (GST_CAT_PIPELINE, "trying delayed link %s:%s to %s:%s",
|
GST_CAT_DEBUG (GST_CAT_PIPELINE, "trying delayed link %s:%s to %s:%s",
|
||||||
GST_ELEMENT_NAME (src), src_pad, GST_ELEMENT_NAME (sink), sink_pad);
|
GST_ELEMENT_NAME (src), src_pad, GST_ELEMENT_NAME (sink), sink_pad);
|
||||||
|
|
||||||
data->src_pad = g_strdup (src_pad);
|
data->src_pad = g_strdup (src_pad);
|
||||||
|
@ -464,7 +463,7 @@ gst_parse_perform_link (link_t *link, graph_t *graph)
|
||||||
g_assert (GST_IS_ELEMENT (src));
|
g_assert (GST_IS_ELEMENT (src));
|
||||||
g_assert (GST_IS_ELEMENT (sink));
|
g_assert (GST_IS_ELEMENT (sink));
|
||||||
|
|
||||||
GST_INFO (GST_CAT_PIPELINE, "linking %s(%s):%u to %s(%s):%u with caps \"%s\"",
|
GST_CAT_INFO (GST_CAT_PIPELINE, "linking %s(%s):%u to %s(%s):%u with caps \"%s\"",
|
||||||
GST_ELEMENT_NAME (src), link->src_name ? link->src_name : "---", g_slist_length (srcs),
|
GST_ELEMENT_NAME (src), link->src_name ? link->src_name : "---", g_slist_length (srcs),
|
||||||
GST_ELEMENT_NAME (sink), link->sink_name ? link->sink_name : "---", g_slist_length (sinks),
|
GST_ELEMENT_NAME (sink), link->sink_name ? link->sink_name : "---", g_slist_length (sinks),
|
||||||
link->caps ? gst_caps_to_string (link->caps) : "-");
|
link->caps ? gst_caps_to_string (link->caps) : "-");
|
||||||
|
@ -777,7 +776,7 @@ _gst_parse_launch (const gchar *str, GError **error)
|
||||||
g.error = error;
|
g.error = error;
|
||||||
|
|
||||||
#ifdef __GST_PARSE_TRACE
|
#ifdef __GST_PARSE_TRACE
|
||||||
GST_DEBUG (GST_CAT_PIPELINE, "TRACE: tracing enabled");
|
GST_CAT_DEBUG (GST_CAT_PIPELINE, "TRACE: tracing enabled");
|
||||||
__strings = __chains = __links = 0;
|
__strings = __chains = __links = 0;
|
||||||
#endif /* __GST_PARSE_TRACE */
|
#endif /* __GST_PARSE_TRACE */
|
||||||
|
|
||||||
|
@ -795,7 +794,7 @@ _gst_parse_launch (const gchar *str, GError **error)
|
||||||
}
|
}
|
||||||
g_free (dstr);
|
g_free (dstr);
|
||||||
|
|
||||||
GST_INFO (GST_CAT_PIPELINE, "got %u elements and %u links", g.chain ? g_slist_length (g.chain->elements) : 0, g_slist_length (g.links));
|
GST_CAT_INFO (GST_CAT_PIPELINE, "got %u elements and %u links", g.chain ? g_slist_length (g.chain->elements) : 0, g_slist_length (g.links));
|
||||||
|
|
||||||
if (!g.chain) {
|
if (!g.chain) {
|
||||||
ret = NULL;
|
ret = NULL;
|
||||||
|
@ -860,7 +859,7 @@ _gst_parse_launch (const gchar *str, GError **error)
|
||||||
|
|
||||||
out:
|
out:
|
||||||
#ifdef __GST_PARSE_TRACE
|
#ifdef __GST_PARSE_TRACE
|
||||||
GST_DEBUG (GST_CAT_PIPELINE, "TRACE: %u strings, %u chains and %u links left", __strings, __chains, __links);
|
GST_CAT_DEBUG (GST_CAT_PIPELINE, "TRACE: %u strings, %u chains and %u links left", __strings, __chains, __links);
|
||||||
if (__strings || __chains || __links) {
|
if (__strings || __chains || __links) {
|
||||||
g_warning ("TRACE: %u strings, %u chains and %u links left", __strings, __chains, __links);
|
g_warning ("TRACE: %u strings, %u chains and %u links left", __strings, __chains, __links);
|
||||||
}
|
}
|
||||||
|
|
|
@ -2,18 +2,17 @@
|
||||||
#include <math.h>
|
#include <math.h>
|
||||||
#include <ctype.h>
|
#include <ctype.h>
|
||||||
#include <string.h>
|
#include <string.h>
|
||||||
|
|
||||||
|
#include "../gst_private.h"
|
||||||
|
|
||||||
#include "types.h"
|
#include "types.h"
|
||||||
#include "../gstinfo.h"
|
#include "../gstinfo.h"
|
||||||
#include "grammar.tab.h"
|
#include "grammar.tab.h"
|
||||||
|
|
||||||
#ifdef HAVE_CONFIG_H
|
|
||||||
#include <config.h>
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#ifdef G_HAVE_ISO_VARARGS
|
#ifdef G_HAVE_ISO_VARARGS
|
||||||
#define PRINT(...) GST_DEBUG (GST_CAT_PIPELINE, "flex: "__VA_ARGS__)
|
#define PRINT(...) GST_CAT_DEBUG (GST_CAT_PIPELINE, "flex: "__VA_ARGS__)
|
||||||
#elif defined(G_HAVE_GNUC_VARARGS)
|
#elif defined(G_HAVE_GNUC_VARARGS)
|
||||||
#define PRINT(args...) GST_DEBUG (GST_CAT_PIPELINE, "flex: "##args)
|
#define PRINT(args...) GST_CAT_DEBUG (GST_CAT_PIPELINE, "flex: "##args)
|
||||||
#else
|
#else
|
||||||
#define PRINT(args...)
|
#define PRINT(args...)
|
||||||
#endif
|
#endif
|
||||||
|
|
|
@ -20,7 +20,10 @@
|
||||||
* Boston, MA 02111-1307, USA.
|
* Boston, MA 02111-1307, USA.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
/* #define DEBUG_ENABLED */
|
#ifdef HAVE_CONFIG_H
|
||||||
|
# include "config.h"
|
||||||
|
#endif
|
||||||
|
|
||||||
#include <stdio.h>
|
#include <stdio.h>
|
||||||
#include <errno.h>
|
#include <errno.h>
|
||||||
#include <sys/types.h>
|
#include <sys/types.h>
|
||||||
|
@ -35,6 +38,7 @@
|
||||||
#include <gst/gstscheduler.h>
|
#include <gst/gstscheduler.h>
|
||||||
#include <gst/gstautoplug.h>
|
#include <gst/gstautoplug.h>
|
||||||
#include <gst/gsturi.h>
|
#include <gst/gsturi.h>
|
||||||
|
#include <gst/gstinfo.h>
|
||||||
|
|
||||||
#include "gstxmlregistry.h"
|
#include "gstxmlregistry.h"
|
||||||
|
|
||||||
|
@ -422,7 +426,7 @@ plugin_times_older_than_recurse(gchar *path, time_t regtime)
|
||||||
time_t pathtime = get_time(path);
|
time_t pathtime = get_time(path);
|
||||||
|
|
||||||
if (pathtime > regtime) {
|
if (pathtime > regtime) {
|
||||||
GST_INFO (GST_CAT_PLUGIN_LOADING,
|
GST_CAT_INFO (GST_CAT_PLUGIN_LOADING,
|
||||||
"time for %s was %ld; more recent than registry time of %ld\n",
|
"time for %s was %ld; more recent than registry time of %ld\n",
|
||||||
path, (long)pathtime, (long)regtime);
|
path, (long)pathtime, (long)regtime);
|
||||||
return FALSE;
|
return FALSE;
|
||||||
|
@ -455,7 +459,7 @@ plugin_times_older_than(GList *paths, time_t regtime)
|
||||||
*/
|
*/
|
||||||
|
|
||||||
while (paths) {
|
while (paths) {
|
||||||
GST_DEBUG (GST_CAT_PLUGIN_LOADING,
|
GST_CAT_DEBUG (GST_CAT_PLUGIN_LOADING,
|
||||||
"comparing plugin times from %s with %ld\n",
|
"comparing plugin times from %s with %ld\n",
|
||||||
(gchar *)paths->data, (long) regtime);
|
(gchar *)paths->data, (long) regtime);
|
||||||
if(!plugin_times_older_than_recurse(paths->data, regtime))
|
if(!plugin_times_older_than_recurse(paths->data, regtime))
|
||||||
|
@ -485,10 +489,10 @@ gst_xml_registry_open_func (GstXMLRegistry *registry, GstXMLRegistryMode mode)
|
||||||
/* if it's not writable, then don't bother */
|
/* if it's not writable, then don't bother */
|
||||||
if (!(gst_registry->flags & GST_REGISTRY_WRITABLE))
|
if (!(gst_registry->flags & GST_REGISTRY_WRITABLE))
|
||||||
{
|
{
|
||||||
GST_INFO (GST_CAT_GST_INIT, "Registry isn't writable");
|
GST_CAT_INFO (GST_CAT_GST_INIT, "Registry isn't writable");
|
||||||
return FALSE;
|
return FALSE;
|
||||||
}
|
}
|
||||||
GST_INFO (GST_CAT_GST_INIT, "Registry doesn't exist, trying to build...");
|
GST_CAT_INFO (GST_CAT_GST_INIT, "Registry doesn't exist, trying to build...");
|
||||||
gst_registry_rebuild (gst_registry);
|
gst_registry_rebuild (gst_registry);
|
||||||
gst_registry_save (gst_registry);
|
gst_registry_save (gst_registry);
|
||||||
/* FIXME: verify that the flags actually get updated ! */
|
/* FIXME: verify that the flags actually get updated ! */
|
||||||
|
@ -502,18 +506,18 @@ gst_xml_registry_open_func (GstXMLRegistry *registry, GstXMLRegistryMode mode)
|
||||||
|
|
||||||
if (!plugin_times_older_than (paths, get_time (registry->location))) {
|
if (!plugin_times_older_than (paths, get_time (registry->location))) {
|
||||||
if (gst_registry->flags & GST_REGISTRY_WRITABLE) {
|
if (gst_registry->flags & GST_REGISTRY_WRITABLE) {
|
||||||
GST_INFO (GST_CAT_GST_INIT, "Registry out of date, rebuilding...");
|
GST_CAT_INFO (GST_CAT_GST_INIT, "Registry out of date, rebuilding...");
|
||||||
|
|
||||||
gst_registry_rebuild (gst_registry);
|
gst_registry_rebuild (gst_registry);
|
||||||
|
|
||||||
gst_registry_save (gst_registry);
|
gst_registry_save (gst_registry);
|
||||||
|
|
||||||
if (!plugin_times_older_than (paths, get_time (registry->location))) {
|
if (!plugin_times_older_than (paths, get_time (registry->location))) {
|
||||||
GST_INFO (GST_CAT_GST_INIT, "Registry still out of date, something is wrong...");
|
GST_CAT_INFO (GST_CAT_GST_INIT, "Registry still out of date, something is wrong...");
|
||||||
return FALSE;
|
return FALSE;
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
GST_INFO (GST_CAT_PLUGIN_LOADING, "Can't write to this registry and it's out of date, ignoring it");
|
GST_CAT_INFO (GST_CAT_PLUGIN_LOADING, "Can't write to this registry and it's out of date, ignoring it");
|
||||||
return FALSE;
|
return FALSE;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -613,7 +617,7 @@ gst_xml_registry_load (GstRegistry *registry)
|
||||||
seconds = g_timer_elapsed (timer, NULL);
|
seconds = g_timer_elapsed (timer, NULL);
|
||||||
g_timer_destroy (timer);
|
g_timer_destroy (timer);
|
||||||
|
|
||||||
GST_INFO (0, "registry: loaded %s in %f seconds\n (%s)",
|
GST_INFO ( "registry: loaded %s in %f seconds\n (%s)",
|
||||||
registry->name, seconds, xmlregistry->location);
|
registry->name, seconds, xmlregistry->location);
|
||||||
|
|
||||||
CLASS (xmlregistry)->close_func (xmlregistry);
|
CLASS (xmlregistry)->close_func (xmlregistry);
|
||||||
|
@ -698,7 +702,7 @@ gst_type_type_find_dummy (GstBuffer *buffer, gpointer priv)
|
||||||
{
|
{
|
||||||
GstTypeFactory *factory = (GstTypeFactory *)priv;
|
GstTypeFactory *factory = (GstTypeFactory *)priv;
|
||||||
|
|
||||||
GST_DEBUG (GST_CAT_TYPES,"gsttype: need to load typefind function for %s", factory->mime);
|
GST_CAT_DEBUG (GST_CAT_TYPES,"gsttype: need to load typefind function for %s", factory->mime);
|
||||||
|
|
||||||
if (gst_plugin_feature_ensure_loaded (GST_PLUGIN_FEATURE (factory))) {
|
if (gst_plugin_feature_ensure_loaded (GST_PLUGIN_FEATURE (factory))) {
|
||||||
if (factory->typefindfunc) {
|
if (factory->typefindfunc) {
|
||||||
|
@ -1613,7 +1617,7 @@ gst_xml_registry_rebuild (GstRegistry *registry)
|
||||||
while (walk) {
|
while (walk) {
|
||||||
gchar *path = (gchar *) walk->data;
|
gchar *path = (gchar *) walk->data;
|
||||||
|
|
||||||
GST_INFO (GST_CAT_PLUGIN_LOADING,
|
GST_CAT_INFO (GST_CAT_PLUGIN_LOADING,
|
||||||
"Rebuilding registry %p in directory %s...", registry, path);
|
"Rebuilding registry %p in directory %s...", registry, path);
|
||||||
|
|
||||||
plugins = g_list_concat (plugins,
|
plugins = g_list_concat (plugins,
|
||||||
|
@ -1654,7 +1658,7 @@ gst_xml_registry_rebuild (GstRegistry *registry)
|
||||||
g_warning ("Bizarre behavior: plugin %s actually loaded",
|
g_warning ("Bizarre behavior: plugin %s actually loaded",
|
||||||
((GstPlugin *) walk->data)->filename);
|
((GstPlugin *) walk->data)->filename);
|
||||||
} else {
|
} else {
|
||||||
GST_INFO (GST_CAT_PLUGIN_LOADING, "Plugin %s failed to load: %s",
|
GST_CAT_INFO (GST_CAT_PLUGIN_LOADING, "Plugin %s failed to load: %s",
|
||||||
((GstPlugin *) walk->data)->filename, error->message);
|
((GstPlugin *) walk->data)->filename, error->message);
|
||||||
g_print ("Plugin %s failed to load\n",
|
g_print ("Plugin %s failed to load\n",
|
||||||
((GstPlugin *) walk->data)->filename);
|
((GstPlugin *) walk->data)->filename);
|
||||||
|
|
Some files were not shown because too many files have changed in this diff Show more
Loading…
Reference in a new issue