atomicqueue: fix race
[platform/upstream/gstreamer.git] / gst / Makefile.am
index 2bf7bbc..0da40a0 100644 (file)
@@ -9,11 +9,7 @@ endif
 if GST_DISABLE_REGISTRY
 GST_REGISTRY_SRC =
 else
-if USE_BINARY_REGISTRY
 GST_REGISTRY_SRC = gstregistrybinary.c
-else
-GST_REGISTRY_SRC = gstregistryxml.c
-endif
 endif
 
 if GST_DISABLE_PARSE
@@ -30,30 +26,12 @@ else
 GST_TRACE_SRC = gsttrace.c
 endif
 
-if GST_DISABLE_ENUMTYPES
-GST_ENUMTYPES_SRC =
-else
-GST_ENUMTYPES_SRC = gstenumtypes.c
-endif
-
-if GST_DISABLE_INDEX
-GST_INDEX_SRC =
-else
-GST_INDEX_SRC = gstindex.c gstindexfactory.c
-endif
-
 if GST_DISABLE_PLUGIN
 GST_PLUGIN_SRC =
 else
 GST_PLUGIN_SRC = gstplugin.c
 endif
 
-if GST_DISABLE_URI
-GST_URI_SRC =
-else
-GST_URI_SRC = gsturi.c
-endif
-
 SUBDIRS = $(SUBDIRS_PARSE)
 
 DIST_SUBDIRS = parse
@@ -63,11 +41,11 @@ DIST_SUBDIRS = parse
 
 built_header_configure = gstconfig.h gstversion.h
 built_header_make = gstenumtypes.h gstmarshal.h
-built_source_make = $(GST_ENUMTYPES_SRC) gstmarshal.c
+built_source_make = gstenumtypes.c gstmarshal.c
 
 EXTRA_libgstreamer_@GST_MAJORMINOR@_la_SOURCES = \
        gstmarshal.list gsttrace.c gstxml.c \
-       gstregistryxml.c gstregistrybinary.c
+       gstregistrybinary.c
 
 
 # temporarily not used
@@ -78,10 +56,12 @@ libgstreamer_@GST_MAJORMINOR@_la_SOURCES = \
        gstobject.c             \
        gstbin.c                \
        gstbuffer.c             \
+       gstbufferlist.c         \
        gstbus.c                \
        gstcaps.c               \
        gstchildproxy.c         \
        gstclock.c              \
+       gstdatetime.c           \
        gstdebugutils.c         \
        gstelement.c            \
        gstelementfactory.c     \
@@ -90,10 +70,12 @@ libgstreamer_@GST_MAJORMINOR@_la_SOURCES = \
        gstfilter.c             \
        gstformat.c             \
        gstghostpad.c           \
-       $(GST_INDEX_SRC)        \
+       gstindex.c              \
+       gstindexfactory.c       \
        gstinfo.c               \
        gstinterface.c          \
        gstiterator.c           \
+       gstatomicqueue.c        \
        gstmessage.c            \
        gstminiobject.c         \
        gstpad.c                \
@@ -102,19 +84,26 @@ libgstreamer_@GST_MAJORMINOR@_la_SOURCES = \
        gstpipeline.c           \
        gstplugin.c             \
        gstpluginfeature.c      \
+       gstpluginloader.c       \
+       gstpoll.c               \
+       gstpreset.c             \
        gstquark.c              \
        gstquery.c              \
        gstregistry.c           \
+       gstregistrychunks.c     \
        gstsegment.c            \
        gststructure.c          \
        gstsystemclock.c        \
        gsttaglist.c            \
        gsttagsetter.c          \
        gsttask.c               \
+       gsttaskpool.c           \
+       gsttoc.c                \
+       gsttocsetter.c          \
        $(GST_TRACE_SRC)        \
        gsttypefind.c           \
        gsttypefindfactory.c    \
-       $(GST_URI_SRC)          \
+       gsturi.c                \
        gstutils.c              \
        gstvalue.c              \
        gstparse.c              \
@@ -136,6 +125,7 @@ DISTCLEANFILES = $(built_header_configure)
 
 libgstreamer_@GST_MAJORMINOR@_la_CFLAGS =              \
        -D_GNU_SOURCE                                   \
+       -DGST_EXPORTS                                   \
        -DG_LOG_DOMAIN=g_log_domain_gstreamer           \
        -DGST_MAJORMINOR=\""$(GST_MAJORMINOR)"\"        \
        -DGST_DISABLE_DEPRECATED                        \
@@ -145,7 +135,9 @@ libgstreamer_@GST_MAJORMINOR@_la_CFLAGS =           \
 libgstreamer_@GST_MAJORMINOR@_la_LIBADD =              \
        $(GST_PARSE_LA)                                 \
        $(GST_ALL_LIBS)                                 \
-       $(XML_LIBS)
+       $(WIN32_LIBS)                                   \
+       $(XML_LIBS)                                     \
+       $(LIBM)
 
 libgstreamer_@GST_MAJORMINOR@_la_LDFLAGS =             \
        $(GST_LIB_LDFLAGS) $(GST_ALL_LDFLAGS) $(GST_LT_LDFLAGS)
@@ -158,11 +150,13 @@ gst_headers =                     \
        gstobject.h             \
        gstbin.h                \
        gstbuffer.h             \
+       gstbufferlist.h         \
        gstbus.h                \
        gstcaps.h               \
        gstchildproxy.h         \
        gstclock.h              \
        gstcompat.h             \
+       gstdatetime.h           \
        gstdebugutils.h         \
        gstelement.h            \
        gstelementfactory.h     \
@@ -176,6 +170,7 @@ gst_headers =                       \
        gstinfo.h               \
        gstinterface.h          \
        gstiterator.h           \
+       gstatomicqueue.h        \
        gstmacros.h             \
        gstmessage.h            \
        gstminiobject.h         \
@@ -185,6 +180,8 @@ gst_headers =                       \
        gstpipeline.h           \
        gstplugin.h             \
        gstpluginfeature.h      \
+       gstpoll.h               \
+       gstpreset.h             \
        gstquery.h              \
        gstsegment.h            \
        gststructure.h          \
@@ -192,6 +189,9 @@ gst_headers =                       \
        gsttaglist.h            \
        gsttagsetter.h          \
        gsttask.h               \
+       gsttaskpool.h           \
+       gsttoc.h                \
+       gsttocsetter.h          \
        gsttrace.h              \
        gsttypefind.h           \
        gsttypefindfactory.h    \
@@ -202,7 +202,8 @@ gst_headers =                       \
        gstparse.h              \
        gstxml.h
 
-libgstreamer_@GST_MAJORMINOR@include_HEADERS = $(gst_headers)
+libgstreamer_@GST_MAJORMINOR@include_HEADERS = $(gst_headers) math-compat.h
+
 nodist_libgstreamer_@GST_MAJORMINOR@include_HEADERS = \
        $(built_header_configure) $(built_header_make)
 
@@ -211,23 +212,26 @@ noinst_HEADERS =          \
        glib-compat-private.h   \
        gst-i18n-lib.h          \
        gst-i18n-app.h          \
+       gstelementdetails.h     \
+       gstpluginloader.h       \
        gstquark.h              \
        gstregistrybinary.h     \
+       gstregistrychunks.h     \
        gst_private.h
 
 gstmarshal.h: gstmarshal.list
-       glib-genmarshal --header --prefix=gst_marshal $(srcdir)/gstmarshal.list > gstmarshal.h.tmp
+       $(AM_V_GEN)glib-genmarshal --header --prefix=gst_marshal $(srcdir)/gstmarshal.list > gstmarshal.h.tmp && \
        mv gstmarshal.h.tmp gstmarshal.h
 
 gstmarshal.c: gstmarshal.list gst_private.h
-       echo "#include \"gst_private.h\"" > gstmarshal.c.tmp
-       echo "#include \"glib-object.h\"" >> gstmarshal.c.tmp
-       echo "#include \"gstmarshal.h\"" >> gstmarshal.c.tmp
-       glib-genmarshal --body --prefix=gst_marshal $(srcdir)/gstmarshal.list >> gstmarshal.c.tmp
+       $(AM_V_GEN)echo "#include \"gst_private.h\"" > gstmarshal.c.tmp && \
+       echo "#include \"glib-object.h\"" >> gstmarshal.c.tmp && \
+       echo "#include \"gstmarshal.h\"" >> gstmarshal.c.tmp && \
+       glib-genmarshal --body --prefix=gst_marshal $(srcdir)/gstmarshal.list >> gstmarshal.c.tmp && \
        mv gstmarshal.c.tmp gstmarshal.c
 
 gstenumtypes.h: $(gst_headers)
-       glib-mkenums \
+       $(AM_V_GEN)glib-mkenums \
        --fhead "#ifndef __GST_ENUM_TYPES_H__\n#define __GST_ENUM_TYPES_H__\n\n#include <glib-object.h>\n\nG_BEGIN_DECLS\n" \
        --fprod "\n/* enumerations from \"@filename@\" */\n" \
        --vhead "GType @enum_name@_get_type (void);\n#define GST_TYPE_@ENUMSHORT@ (@enum_name@_get_type())\n"         \
@@ -235,15 +239,90 @@ gstenumtypes.h: $(gst_headers)
        $^ > gstenumtypes.h
 
 gstenumtypes.c: $(gst_headers)
-       glib-mkenums \
+       $(AM_V_GEN)glib-mkenums \
        --fhead "#include \"gst_private.h\"\n#include <gst/gst.h>\n#define C_ENUM(v) ((gint) v)\n#define C_FLAGS(v) ((guint) v)\n " \
        --fprod "\n/* enumerations from \"@filename@\" */" \
-       --vhead "static void\nregister_@enum_name@ (GType* id)\n{\n  static const G@Type@Value values[] = {"     \
+       --vhead "GType\n@enum_name@_get_type (void)\n{\n  static gsize id = 0;\n  static const G@Type@Value values[] = {"     \
        --vprod "    { C_@TYPE@(@VALUENAME@), \"@VALUENAME@\", \"@valuenick@\" }," \
-       --vtail "    { 0, NULL, NULL }\n  };\n  *id = g_@type@_register_static (\"@EnumName@\", values);\n}\nGType\n@enum_name@_get_type (void)\n{\n  static GType id;\n  static GOnce once = G_ONCE_INIT;\n\n  g_once (&once, (GThreadFunc)register_@enum_name@, &id);\n  return id;\n}\n" \
+       --vtail "    { 0, NULL, NULL }\n  };\n\n  if (g_once_init_enter (&id)) {\n    GType tmp = g_@type@_register_static (\"@EnumName@\", values);\n    g_once_init_leave (&id, tmp);\n  }\n\n  return (GType) id;\n}" \
        $^ > gstenumtypes.c
 
 %.c.gcov: .libs/libgstreamer_@GST_MAJORMINOR@_la-%.gcda %.c
        $(GCOV) -b -f -o $^ > $@.out
 
 gcov: $(libgstreamer_@GST_MAJORMINOR@_la_SOURCES:=.gcov)
+
+Android.mk: Makefile.am
+       androgenizer -:PROJECT gstreamer -:SHARED libgstreamer-@GST_MAJORMINOR@ \
+        -:TAGS eng debug \
+         -:REL_TOP $(top_srcdir) -:ABS_TOP $(abs_top_srcdir) \
+        -:SOURCES $(libgstreamer_@GST_MAJORMINOR@_la_SOURCES) \
+                  $(nodist_libgstreamer_@GST_MAJORMINOR@_la_SOURCES) \
+        -:CFLAGS $(DEFS) $(libgstreamer_@GST_MAJORMINOR@_la_CFLAGS) \
+        -:LDFLAGS $(libgstreamer_@GST_MAJORMINOR@_la_LDFLAGS) \
+                  $(libgstreamer_@GST_MAJORMINOR@_la_LIBADD) \
+                  -ldl \
+        -:SUBDIR gst/parse \
+        -:HEADER_TARGET gstreamer-@GST_MAJORMINOR@/gst \
+        -:HEADERS $(libgstreamer_@GST_MAJORMINOR@include_HEADERS) \
+        -:LIBFILTER_STATIC gstparse \
+        -:PASSTHROUGH LOCAL_ARM_MODE:=arm \
+       > $@
+
+if HAVE_INTROSPECTION
+BUILT_GIRSOURCES = Gst-@GST_MAJORMINOR@.gir
+
+gir_headers=$(patsubst %,$(srcdir)/%, $(libgstreamer_@GST_MAJORMINOR@include_HEADERS))
+gir_sources=$(patsubst %,$(srcdir)/%, $(libgstreamer_@GST_MAJORMINOR@_la_SOURCES))
+
+Gst-@GST_MAJORMINOR@.gir: $(INTROSPECTION_SCANNER) libgstreamer-@GST_MAJORMINOR@.la
+       $(AM_V_GEN)GST_PLUGIN_SYSTEM_PATH="" GST_PLUGIN_PATH="" GST_REGISTRY_UPDATE=no \
+               $(INTROSPECTION_SCANNER) -v --namespace Gst \
+               --nsversion=@GST_MAJORMINOR@ \
+               -I$(top_srcdir) \
+               -I$(top_builddir) \
+               -DIN_GOBJECT_INTROSPECTION=1 \
+               --c-include='gst/gst.h' \
+               --library=libgstreamer-0.10.la \
+               --include=GLib-2.0 \
+               --include=GObject-2.0 \
+               --include=GModule-2.0 \
+               --include=libxml2-2.0 \
+               --libtool="$(top_builddir)/libtool" \
+               --pkg glib-2.0 \
+               --pkg gobject-2.0 \
+               --pkg gmodule-no-export-2.0 \
+               --pkg gthread-2.0 \
+               --pkg libxml-2.0 \
+               --pkg-export gstreamer-0.10 \
+               --add-init-section="gst_init(NULL, NULL);" \
+               --output $@ \
+               $(gir_headers) \
+               $(gir_sources)
+
+# INTROSPECTION_GIRDIR/INTROSPECTION_TYPELIBDIR aren't the right place to
+# install anything - we need to install inside our prefix.
+girdir = $(datadir)/gir-1.0
+gir_DATA = $(BUILT_GIRSOURCES)
+
+typelibsdir = $(libdir)/girepository-1.0/
+
+typelibs_DATA = $(BUILT_GIRSOURCES:.gir=.typelib)
+
+%.typelib: %.gir $(INTROSPECTION_COMPILER)
+       $(AM_V_GEN)$(INTROSPECTION_COMPILER) --includedir=$(srcdir) --includedir=$(builddir) $(INTROSPECTION_COMPILER_OPTS) $< -o $(@F)
+
+CLEANFILES += $(BUILT_GIRSOURCES) $(typelibs_DATA)
+endif
+
+# try to prevent packaging errors
+check-libexecdir-consistency:
+       @if test "${GST_PLUGIN_SCANNER_INSTALLED}" != "${libexecdir}/gstreamer-$(GST_MAJORMINOR)/gst-plugin-scanner"; then \
+         echo "*** Inconsistent libexecdir! Please use ./configure --libexecdir=/foo/bar"; \
+         echo "*** to set the libexecdir and not make libexecdir=/foo/bar or the like."; \
+         echo "*** The same goes for prefix, libdir etc."; \
+         echo "*** ${GST_PLUGIN_SCANNER_INSTALLED} != ${libexecdir}/gstreamer-$(GST_MAJORMINOR)/gst-plugin-scanner"; \
+         exit 1; \
+       fi
+
+all-local: check-libexecdir-consistency