X-Git-Url: http://review.tizen.org/git/?a=blobdiff_plain;f=configure.ac;h=3717518597c9804f77020bab3229afe02c427dbb;hb=632431aecbbc75c91526db26d312e3cbfab015d4;hp=aede004c9151dc3888072946ce2f974273e79ceb;hpb=007a00cd1bb4dfacc7c5aefb71f54770c2d21093;p=platform%2Fupstream%2Fgstreamer.git diff --git a/configure.ac b/configure.ac index aede004..3717518 100644 --- a/configure.ac +++ b/configure.ac @@ -1,15 +1,14 @@ -AC_PREREQ(2.60) +AC_PREREQ([2.69]) dnl initialize autoconf dnl when going to/from release please set the nano (fourth number) right ! dnl releases only do Wall, git and prerelease does Werror too -AC_INIT(GStreamer, 0.11.2.1, - http://bugzilla.gnome.org/enter_bug.cgi?product=GStreamer, - gstreamer) +dnl +AC_INIT([GStreamer],[1.5.1.1],[http://bugzilla.gnome.org/enter_bug.cgi?product=GStreamer],[gstreamer]) AG_GST_INIT dnl initialize automake (we require GNU make) -AM_INIT_AUTOMAKE([-Wno-portability 1.10]) +AM_INIT_AUTOMAKE([-Wno-portability 1.14 no-dist-gzip dist-xz tar-ustar subdir-objects]) dnl define PACKAGE_VERSION_* variables AS_VERSION @@ -21,42 +20,49 @@ dnl can autoconf find the source ? AC_CONFIG_SRCDIR([gst/gst.c]) dnl define the output header for config -AM_CONFIG_HEADER([config.h]) +AC_CONFIG_HEADERS([config.h]) dnl AM_MAINTAINER_MODE only provides the option to configure to enable it -AM_MAINTAINER_MODE +AM_MAINTAINER_MODE([enable]) dnl sets host_* variables AC_CANONICAL_HOST -dnl use pretty build output with automake >= 1.11 -m4_ifdef([AM_SILENT_RULES],[AM_SILENT_RULES([yes])], - [AM_DEFAULT_VERBOSITY=1 - AC_SUBST(AM_DEFAULT_VERBOSITY)]) - -dnl our libraries and install dirs use major.minor as a version -GST_MAJORMINOR=$PACKAGE_VERSION_MAJOR.$PACKAGE_VERSION_MINOR -dnl we override it here for release candidates for a new series -GST_MAJORMINOR=0.11 -AC_SUBST(GST_MAJORMINOR) -AC_DEFINE_UNQUOTED(GST_MAJORMINOR, "$GST_MAJORMINOR", - [library major.minor version]) +dnl use pretty build output by default +AM_SILENT_RULES([yes]) + +dnl GStreamer versioning, this is mostly informational +GST_VERSION_MAJOR=$PACKAGE_VERSION_MAJOR +GST_VERSION_MINOR=$PACKAGE_VERSION_MINOR +GST_VERSION_MICRO=$PACKAGE_VERSION_MICRO +GST_VERSION_NANO=$PACKAGE_VERSION_NANO +AC_SUBST(GST_VERSION_MAJOR) +AC_SUBST(GST_VERSION_MINOR) +AC_SUBST(GST_VERSION_MICRO) +AC_SUBST(GST_VERSION_NANO) + +dnl our libraries and install dirs use GST_API_VERSION in the filename +dnl to allow side-by-side installation of different API versions +GST_API_VERSION=1.0 +AC_SUBST(GST_API_VERSION) +AC_DEFINE_UNQUOTED(GST_API_VERSION, "$GST_API_VERSION", + [GStreamer API Version]) dnl CURRENT, REVISION, AGE dnl - library source changed -> increment REVISION dnl - interfaces added/removed/changed -> increment CURRENT, REVISION = 0 dnl - interfaces added -> increment AGE dnl - interfaces removed -> AGE = 0 +dnl +dnl Keep CURRENT as MINOR * 100 + MICRO +dnl Ex : 1.0.0 => 0 +dnl 1.0.3 => 3 +dnl 1.1.0 => 100 +dnl 1.2.5 => 205 +dnl 1.10.9 (who knows) => 1009 +dnl dnl sets GST_LT_LDFLAGS -AS_LIBTOOL(GST, 32, 0, 0) - -dnl FIXME: this macro doesn't actually work; -dnl the generated libtool script has no support for the listed tags. -dnl So this needs to be fixed first if we want to use this -dnl AS_LIBTOOL_TAGS - -AC_LIBTOOL_WIN32_DLL -AM_PROG_LIBTOOL +AS_LIBTOOL(GST, 501, 0, 501) dnl *** autotools stuff **** @@ -70,7 +76,7 @@ dnl set up gettext dnl the version check needs to stay here because autopoint greps for it AM_GNU_GETTEXT_VERSION([0.17]) AM_GNU_GETTEXT([external]) -AG_GST_GETTEXT([gstreamer-$GST_MAJORMINOR]) +AG_GST_GETTEXT([gstreamer-$GST_API_VERSION]) dnl *** check for arguments to configure *** @@ -126,9 +132,62 @@ AG_GST_SET_PACKAGE_RELEASE_DATETIME_WITH_NANO([$PACKAGE_VERSION_NANO], ["${srcdir}/gstreamer.doap"], [$PACKAGE_VERSION_MAJOR.$PACKAGE_VERSION_MINOR.$PACKAGE_VERSION_MICRO]) +dnl check for bash completion +AC_ARG_WITH([bash-completion-dir], + AS_HELP_STRING([--with-bash-completion-dir[=PATH]], + [Install the bash auto-completion script in this directory. @<:@default=yes@:>@]), + [], + [with_bash_completion_dir=yes]) + +if test "x$with_bash_completion_dir" = "xyes" +then + extra_args= + + if test "x$prefix" != "xNONE" + then + extra_args="--define-variable=prefix=\"$prefix\"" + fi + + PKG_CHECK_MODULES([BASH_COMPLETION], [bash-completion >= 2.0], + [BASH_COMPLETION_DIR="`eval pkg-config $extra_args --variable=completionsdir bash-completion`"], + [BASH_COMPLETION_DIR="$datadir/bash-completion/completions"]) + PKG_CHECK_MODULES([BASH_COMPLETION], [bash-completion >= 2.0], + [BASH_HELPERS_DIR="`eval pkg-config $extra_args --variable=helpersdir bash-completion`"], + [BASH_HELPERS_DIR="$datadir/bash-completion/helpers"]) +else + BASH_COMPLETION_DIR="$with_bash_completion_dir/completions" + BASH_HELPERS_DIR="$with_bash_completion_dir/helpers" +fi + +AC_SUBST([BASH_COMPLETION_DIR]) +AC_SUBST([BASH_HELPERS_DIR]) +AM_CONDITIONAL([ENABLE_BASH_COMPLETION],[test "x$with_bash_completion_dir" != "xno"]) + +dnl build static plugins or not +AC_MSG_CHECKING([whether to build static plugins or not]) +AC_ARG_ENABLE( + static-plugins, + AC_HELP_STRING( + [--enable-static-plugins], + [build static plugins @<:@default=no@:>@]), + [AS_CASE( + [$enableval], [no], [], [yes], [], + [AC_MSG_ERROR([bad value "$enableval" for --enable-static-plugins])])], + [enable_static_plugins=no]) +AC_MSG_RESULT([$enable_static_plugins]) +if test "x$enable_static_plugins" = xyes; then + AC_DEFINE(GST_PLUGIN_BUILD_STATIC, 1, + [Define if static plugins should be built]) + GST_PLUGIN_LIBTOOLFLAGS="" +else + GST_PLUGIN_LIBTOOLFLAGS="--tag=disable-static" +fi +AC_SUBST(GST_PLUGIN_LIBTOOLFLAGS) +AM_CONDITIONAL(GST_PLUGIN_BUILD_STATIC, test "x$enable_static_plugins" = "xyes") + dnl building of tests AC_ARG_ENABLE(tests, - AC_HELP_STRING([--disable-tests], [disable building test apps]), + AS_HELP_STRING([--disable-tests],[disable building test apps]), [ case "${enableval}" in yes) BUILD_TESTS=yes ;; @@ -141,8 +200,7 @@ AM_CONDITIONAL(BUILD_TESTS, test "x$BUILD_TESTS" = "xyes") dnl tests known to fail AC_ARG_ENABLE(failing-tests, - AC_HELP_STRING([--disable-failing-tests], - [disable building tests known to fail]), + AS_HELP_STRING([--disable-failing-tests],[disable building tests known to fail]), [ case "${enableval}" in yes) BUILD_FAILING_TESTS=yes ;; @@ -158,10 +216,35 @@ else AC_MSG_WARN([Sissy ! By asking to not build the tests known to fail, you hereby waive your right to customer support. If you do not agree with this EULA, please press Ctrl-C before the next line is printed. By allowing the next line to be printed, you expressly acknowledge your acceptance of this EULA.]) fi +dnl building of benchmarks +AC_ARG_ENABLE(benchmarks, + AS_HELP_STRING([--disable-benchmarks],[disable building benchmarks apps]), + [ + case "${enableval}" in + yes) BUILD_BENCHMARKS=yes ;; + no) BUILD_BENCHMARKS=no ;; + *) AC_MSG_ERROR(bad value ${enableval} for --disable-benchmarks) ;; + esac + ], +[BUILD_BENCHMARKS=yes]) dnl Default value +AM_CONDITIONAL(BUILD_BENCHMARKS, test "x$BUILD_BENCHMARKS" = "xyes") + +dnl building of tools +AC_ARG_ENABLE(tools, + AS_HELP_STRING([--disable-tools],[disable building tools]), + [ + case "${enableval}" in + yes) BUILD_TOOLS=yes ;; + no) BUILD_TOOLS=no ;; + *) AC_MSG_ERROR(bad value ${enableval} for --disable-tools) ;; + esac + ], +[BUILD_TOOLS=yes]) dnl Default value +AM_CONDITIONAL(BUILD_TOOLS, test "x$BUILD_TOOLS" = "xyes") + dnl poison destroyed objects AC_ARG_ENABLE(poisoning, - AC_HELP_STRING([--enable-poisoning], - [enable poisoning of deallocated objects]), + AS_HELP_STRING([--enable-poisoning],[enable poisoning of deallocated objects]), [ case "${enableval}" in yes) USE_POISONING=yes ;; @@ -175,6 +258,143 @@ if test "x$USE_POISONING" = xyes; then [Define if we should poison deallocated memory]) fi +dnl PTP support parts +AC_MSG_CHECKING([whether PTP support can be enabled]) +case "$host_os" in + *android*) + dnl Can't run on Android because of permissions + HAVE_PTP=no + ;; + mingw*|pw32*|cygwin*) + dnl Not ported to Windows yet + HAVE_PTP=no + ;; + darwin*) + dnl Can't run on iOS because of permissions + AC_CHECK_HEADER(MobileCoreServices/MobileCoreServices.h, HAVE_PTP="no", HAVE_PTP="yes", [-]) + ;; + linux*|darwin*|solaris*|netbsd*|freebsd*|openbsd*|kfreebsd*|dragonfly*|gnu*) + HAVE_PTP=yes + ;; + *) + HAVE_PTP=no + ;; +esac +AC_MSG_RESULT([$HAVE_PTP]) + +dnl user/group to change to in gst-ptp-helper +AC_ARG_WITH([ptp-helper-setuid-user], + AS_HELP_STRING([--with-ptp-helper-setuid-user],[User to switch to when installing gst-ptp-helper setuid root]), + [ + if test "x$withval" != "x" + then + AC_DEFINE_UNQUOTED(HAVE_PTP_HELPER_SETUID_USER, "$withval", [PTP helper setuid user]) + fi + ], [] +) + +dnl group/group to change to in gst-ptp-helper +AC_ARG_WITH([ptp-helper-setuid-group], + AS_HELP_STRING([--with-ptp-helper-setuid-group],[Group to switch to when installing gst-ptp-helper setuid root]), + [ + if test "x$withval" != "x" + then + AC_DEFINE_UNQUOTED(HAVE_PTP_HELPER_SETUID_GROUP, "$withval", [PTP helper setuid group]) + fi + ], [] +) + +AC_ARG_WITH( + ptp-helper-permissions, + AC_HELP_STRING( + [--with-ptp-helper-permissions], + [how to gain PTP permissions (none, setuid-root, capabilities, auto)]), + [], + [with_ptp_helper_permissions=auto]) + +gst_ptp_have_cap=no +AG_GST_CHECK_LIBHEADER(CAP, cap, + cap_init, , + sys/capability.h, + CAP_LIBS="-lcap" + AC_SUBST(CAP_LIBS) + gst_ptp_have_cap=yes) + +AC_PATH_PROG([SETCAP], [setcap], [no], [$PATH:/usr/bin:/bin:/usr/sbin:/sbin]) + +if test "x$HAVE_PTP" = "xyes"; then +AC_DEFINE(HAVE_PTP, 1, [PTP support available]) + +AC_MSG_CHECKING([for SIOCGIFCONF, SIOCGIFFLAGS and SIOCGIFHWADDR]) +AC_COMPILE_IFELSE([AC_LANG_PROGRAM( + [[ + #include + #include + ]], + [[ + struct ifreq ifr; + struct ifconf ifc; + ioctl(0, SIOCGIFCONF, &ifc); + ioctl(0, SIOCGIFFLAGS, &ifr); + ioctl(0, SIOCGIFHWADDR, &ifr); + int dummy = ifr.ifr_hwaddr.sa_data[0]; + ]])], [ + AC_MSG_RESULT(yes) + AC_DEFINE(HAVE_SIOCGIFCONF_SIOCGIFFLAGS_SIOCGIFHWADDR, 1, [SIOCGIFCONF, SIOCGIFFLAGS and SIOCGIFHWADDR is available]) + ], [ + AC_MSG_RESULT(no) +]) + +AC_MSG_CHECKING([for getifaddrs() and AF_LINK]) +AC_COMPILE_IFELSE([AC_LANG_PROGRAM( + [[ + #include + #include + #include + ]], + [[ + struct ifaddrs *ifaddr; + getifaddrs(&ifaddr); + int dummy = (ifaddr->ifa_flags & IFF_LOOPBACK) && ifaddr->ifa_addr->sa_family != AF_LINK; + ]])], [ + AC_MSG_RESULT(yes) + AC_DEFINE(HAVE_GETIFADDRS_AF_LINK, 1, [getifaddrs() and AF_LINK is available]) + ], [ + AC_MSG_RESULT(no) + ]) + +AC_MSG_CHECKING([how to install gst-ptp-helper]) +if test "x$with_ptp_helper_permissions" = "xauto"; then + if test "x$gst_ptp_have_cap" = "xyes" -a "x$SETCAP" != "xno"; then + with_ptp_helper_permissions="capabilities" + else + with_ptp_helper_permissions="setuid-root" + fi +fi +AC_MSG_RESULT([$with_ptp_helper_permissions]) + +case "$with_ptp_helper_permissions" in + none) + ;; + setuid-root) + AC_DEFINE(HAVE_PTP_HELPER_SETUID, 1, + [Use setuid-root for permissions in PTP helper]) + ;; + capabilities) + AC_DEFINE(HAVE_PTP_HELPER_CAPABILITIES, 1, + [Use capabilities for permissions in PTP helper]) + ;; + *) + AC_MSG_ERROR(Invalid parameter [$with_ptp_helper_permissions]) + ;; +esac + +fi + +AM_CONDITIONAL(HAVE_PTP, test "x$HAVE_PTP" = "xyes") +AM_CONDITIONAL(HAVE_PTP_HELPER_SETUID, test "x$with_ptp_helper_permissions" = "xsetuid-root") +AM_CONDITIONAL(HAVE_PTP_HELPER_CAPABILITIES, test "x$with_ptp_helper_permissions" = "xcapabilities") + dnl *** checks for platform *** dnl * hardware/architecture * @@ -223,7 +443,7 @@ AC_PROG_CXX dnl CXX may be set to some default even if no c++ compiler is available dnl (thanks autotools!), so just try to compile some c++ code to make sure AC_LANG_PUSH([C++]) -AC_TRY_COMPILE([ class Foo { int bar; };], , working_cxx=yes, working_cxx=no) +AC_COMPILE_IFELSE([AC_LANG_PROGRAM([[ class Foo { int bar; };]], [[]])],[working_cxx=yes],[working_cxx=no]) AC_LANG_POP([C++]) AC_MSG_NOTICE([working c++ compiler found: $working_cxx]) AM_CONDITIONAL(HAVE_CXX, test "x$working_cxx" = "xyes") @@ -248,14 +468,13 @@ GOBJECT_INTROSPECTION_CHECK([1.31.1]) dnl check for documentation tools AG_GST_DOCBOOK_CHECK -GTK_DOC_CHECK([1.3]) -AS_PATH_PYTHON([2.1]) -AG_GST_PLUGIN_DOCS([1.3],[2.1]) +GTK_DOC_CHECK([1.12]) +AG_GST_PLUGIN_DOCS([1.12]) dnl *** checks for libraries *** dnl check for libm, for sin() -AC_CHECK_LIBM +LT_LIB_M AC_SUBST(LIBM) dnl *** checks for header files *** @@ -264,40 +483,57 @@ dnl check if we have ANSI C header files AC_HEADER_STDC dnl Check for ucontext.h -AC_CHECK_HEADERS([ucontext.h]) +AC_CHECK_HEADERS([ucontext.h], [], [], [AC_INCLUDES_DEFAULT]) dnl Check for sys/socket.h -AC_CHECK_HEADERS([sys/socket.h], HAVE_SYS_SOCKET_H=yes) +AC_CHECK_HEADERS([sys/socket.h], [HAVE_SYS_SOCKET_H=yes], [HAVE_SYS_SOCKET_H=no], [AC_INCLUDES_DEFAULT]) AM_CONDITIONAL(HAVE_SYS_SOCKET_H, test "x$HAVE_SYS_SOCKET_H" = "xyes") dnl check for sys/times.h for tests/examples/adapter/ -AC_CHECK_HEADERS([sys/times.h], HAVE_SYS_TIMES_H=yes) -AC_CHECK_HEADERS([unistd.h], HAVE_UNISTD_H=yes) +AC_CHECK_HEADERS([sys/times.h], [HAVE_SYS_TIMES_H=yes], [HAVE_SYS_TIME_H=no], [AC_INCLUDES_DEFAULT]) +AC_CHECK_HEADERS([unistd.h], [HAVE_UNISTD_H=yes], [HAVE_UNISTD_H=no], [AC_INCLUDES_DEFAULT]) AM_CONDITIONAL(HAVE_SYS_TIMES_H_AND_UNISTD_H, test "x$HAVE_SYS_TIMES_H" = "xyes" -a "x$HAVE_UNISTD_H" = "xyes") dnl Check for process.h for getpid() on win32 -AC_CHECK_HEADERS([process.h]) +AC_CHECK_HEADERS([process.h], [], [], [AC_INCLUDES_DEFAULT]) dnl Check for sys/utsname.h for uname -AC_CHECK_HEADERS([sys/utsname.h]) +AC_CHECK_HEADERS([sys/utsname.h], [], [], [AC_INCLUDES_DEFAULT]) dnl Check for stdio_ext.f for __fbufsize -AC_CHECK_HEADERS([stdio_ext.h]) +AC_CHECK_HEADERS([stdio_ext.h], [], [], [AC_INCLUDES_DEFAULT]) dnl check for pthreads -AC_CHECK_HEADERS([pthread.h], HAVE_PTHREAD_H=yes) -AM_CONDITIONAL(HAVE_PTHREAD_H, test "x$HAVE_PTHREAD_H" = "xyes") +dnl without arguments AX_PTHREAD() will do AC_DEFINE(HAVE_PTHREAD) +dnl which later checks use in their test code +AX_PTHREAD() +AM_CONDITIONAL(HAVE_PTHREAD, test "x$ax_pthread_ok" = "xyes") dnl check for sys/prctl for setting thread name on Linux -AC_CHECK_HEADERS([sys/prctl.h], HAVE_SYS_PRCTL_H=yes) +AC_CHECK_HEADERS([sys/prctl.h], [], [], [AC_INCLUDES_DEFAULT]) + +dnl check for pthread_setname_np(const char*) +dnl which is present on OS X 10.6, iOS 3.2 and above +AC_MSG_CHECKING(for pthread_setname_np(const char*)) +AC_LINK_IFELSE( + [AC_LANG_PROGRAM( + [#include ], + [pthread_setname_np("example")])], + [AC_MSG_RESULT(yes) + AC_DEFINE(HAVE_PTHREAD_SETNAME_NP_WITHOUT_TID,1, + [Have function pthread_setname_np(const char*)])], + [AC_MSG_RESULT(no)]) + +dnl check for sys/uio.h for writev() +AC_CHECK_HEADERS([sys/uio.h], [], [], [AC_INCLUDES_DEFAULT]) dnl Check for valgrind.h dnl separate from HAVE_VALGRIND because you can have the program, but not dnl the dev package -AC_CHECK_HEADERS([valgrind/valgrind.h], HAVE_VALGRIND_H=yes) +AC_CHECK_HEADERS([valgrind/valgrind.h], [], [], [AC_INCLUDES_DEFAULT]) dnl used in gst/gstpoll.c -AC_CHECK_HEADERS([winsock2.h], HAVE_WINSOCK2_H=yes) +AC_CHECK_HEADERS([winsock2.h], [HAVE_WINSOCK2_H=yes], [HAVE_WINSOCK2_H=no], [AC_INCLUDES_DEFAULT]) AM_CONDITIONAL(HAVE_WINSOCK2_H, test "x$HAVE_WINSOCK2_H" = "xyes") if test "x$HAVE_WINSOCK2_H" = "xyes"; then WIN32_LIBS="-lws2_32" @@ -330,14 +566,14 @@ dnl check if the compiler supports __uint128_t (gcc) dnl Actually check for 128-bit division, since that's what we use dnl uint128_t for. AC_CACHE_CHECK(for __uint128_t, gst_cv_uint128_t, - AC_TRY_LINK([ ], [ + AC_LINK_IFELSE([AC_LANG_PROGRAM([[ ]], [[ static __uint128_t v1 = 100; static __uint128_t v2 = 10; static __uint128_t u; u = v1 / v2; - ], [ + ]])],[ gst_cv_uint128_t=yes - ], [ + ],[ gst_cv_uint128_t=no ]) ) @@ -363,6 +599,8 @@ AC_MSG_RESULT($have_tm_gmtoff) dnl *** checks for library functions *** +AC_CHECK_FUNCS([strcasestr]) + AC_CHECK_FUNCS([gmtime_r]) AC_CHECK_FUNCS([localtime_r]) AC_CHECK_FUNCS([sigaction]) @@ -376,12 +614,12 @@ AC_CHECK_FUNCS([fgetpos]) AC_CHECK_FUNCS([fsetpos]) dnl check for poll(), ppoll() and pselect() +AC_CHECK_HEADERS([sys/poll.h], [], [], [AC_INCLUDES_DEFAULT]) +AC_CHECK_HEADERS([poll.h], [], [], [AC_INCLUDES_DEFAULT]) AC_CHECK_FUNCS([poll]) AC_CHECK_FUNCS([ppoll]) AC_CHECK_FUNCS([pselect]) -AC_CHECK_HEADERS([sys/poll.h]) - dnl **************************************** dnl *** GLib POLL* compatibility defines *** dnl **************************************** @@ -390,10 +628,12 @@ AC_MSG_CHECKING([for broken poll]) AC_RUN_IFELSE([AC_LANG_SOURCE([[ #include #include - #include #ifdef HAVE_SYS_POLL_H #include #endif + #ifdef HAVE_POLL_H + #include + #endif int main(void) { struct pollfd fds[1]; int fd; @@ -425,22 +665,27 @@ AC_CHECK_FUNCS(clock_gettime, [], [ AC_CHECK_LIB(rt, clock_gettime, [ AC_DEFINE(HAVE_CLOCK_GETTIME, 1) LIBS="$LIBS -lrt" + ], [ + AC_CHECK_LIB(pthread, clock_gettime, [ + AC_DEFINE(HAVE_CLOCK_GETTIME, 1) + LIBS="$LIBS -lpthread" + ]) ]) ]) AC_CACHE_CHECK(for posix timers, gst_cv_posix_timers, - AC_TRY_COMPILE([ + AC_COMPILE_IFELSE([AC_LANG_PROGRAM([[ #include #ifdef HAVE_UNISTD_H #include #endif - ], [ + ]], [[ #if !defined(_POSIX_TIMERS) || _POSIX_TIMERS < 0 || !defined(CLOCK_REALTIME) #error Either _POSIX_TIMERS or CLOCK_REALTIME not defined #endif - ], [ + ]])],[ gst_cv_posix_timers=yes - ], [ + ],[ gst_cv_posix_timers=no ]) ) @@ -455,18 +700,18 @@ AC_SUBST(GST_HAVE_POSIX_TIMERS_DEFINE) AM_CONDITIONAL(GST_HAVE_POSIX_TIMERS, test "$gst_cv_posix_timers" = "yes") AC_CACHE_CHECK(for monotonic clock, gst_cv_monotonic_clock, - AC_TRY_COMPILE([ + AC_COMPILE_IFELSE([AC_LANG_PROGRAM([[ #include #ifdef HAVE_UNISTD_H #include #endif - ], [ + ]], [[ #if !defined(_POSIX_MONOTONIC_CLOCK) || _POSIX_MONOTONIC_CLOCK < 0 || !defined(CLOCK_MONOTONIC) #error Either _POSIX_MONOTONIC_CLOCK or CLOCK_MONOTONIC not defined #endif - ], [ + ]])],[ gst_cv_monotonic_clock=yes - ], [ + ],[ gst_cv_monotonic_clock=no ]) ) @@ -483,25 +728,6 @@ AM_CONDITIONAL(GST_HAVE_MONOTONIC_CLOCK, test "$gst_cv_monotonic_clock" = "yes") dnl Check for a way to display the function name in debug output AG_GST_CHECK_FUNCTION -dnl test for register_printf_specifier or register_printf_function -AC_CHECK_FUNCS([register_printf_specifier register_printf_function], - [HAVE_PRINTF_EXTENSION=yes]) - -if test "$HAVE_PRINTF_EXTENSION" = yes; then - GST_PRINTF_EXTENSION_POINTER_FORMAT_DEFINE="#define GST_PTR_FORMAT \"P\"" - GST_PRINTF_EXTENSION_SEGMENT_FORMAT_DEFINE="#define GST_SEGMENT_FORMAT \"Q\"" - GST_USING_PRINTF_EXTENSION_DEFINE="#define GST_USING_PRINTF_EXTENSION" - AC_DEFINE(HAVE_PRINTF_EXTENSION, 1, - [Defined if we have printf specifier extensions available]) -else - GST_PRINTF_EXTENSION_POINTER_FORMAT_DEFINE="#define GST_PTR_FORMAT \"p\"" - GST_PRINTF_EXTENSION_SEGMENT_FORMAT_DEFINE="#define GST_SEGMENT_FORMAT \"p\"" - GST_USING_PRINTF_EXTENSION_DEFINE="#undef GST_USING_PRINTF_EXTENSION" -fi -AC_SUBST(GST_PRINTF_EXTENSION_POINTER_FORMAT_DEFINE) -AC_SUBST(GST_PRINTF_EXTENSION_SEGMENT_FORMAT_DEFINE) -AC_SUBST(GST_USING_PRINTF_EXTENSION_DEFINE) - dnl test if we have dladdr(); we use it for debugging; see gst/gstinfo.c save_cflags="$CFLAGS" CFLAGS="$CFLAGS -D_GNU_SOURCE" @@ -510,10 +736,31 @@ AC_CHECK_LIB(dl, dladdr, LIBS="$LIBS -ldl") CFLAGS="$save_cflags" +dnl Check printf stuff +if test "x${GST_DISABLE_GST_DEBUG}" != "xyes"; then + AC_TYPE_LONG_LONG_INT + AC_TYPE_UNSIGNED_LONG_LONG_INT + + if test x$ac_cv_type_long_long_int$ac_cv_type_unsigned_long_long_int = xyesyes; then + AC_DEFINE([HAVE_LONG_LONG], [1], [Define to 1 if the system has the type long long]) + fi + + dnl /usr/share/aclocal/inttypes_h.m4 - ships with gettext apparently + gl_AC_HEADER_INTTYPES_H + + dnl /usr/share/aclocal/stdint_h.m4 - ships with gettext apparently + gl_AC_HEADER_STDINT_H + + AC_CHECK_TYPES(ptrdiff_t) + + AC_TYPE_INTMAX_T + AC_TYPE_SIZE_T +fi + dnl *** checks for dependency libraries *** dnl GLib -GLIB_REQ=2.31.14 +GLIB_REQ=2.32.0 AG_GST_GLIB_CHECK([$GLIB_REQ]) dnl Check for documentation xrefs @@ -522,7 +769,7 @@ AC_SUBST(GLIB_PREFIX) dnl building of unit test libraries AC_ARG_ENABLE(check, - AC_HELP_STRING([--disable-check], [disable building unit test libraries]), + AS_HELP_STRING([--disable-check],[disable building unit test libraries]), [ case "${enableval}" in yes) BUILD_CHECK=yes ;; @@ -562,16 +809,15 @@ AC_ARG_WITH([memory-alignment], dnl Check for -Bsymbolic-functions linker flag used to avoid dnl intra-library PLT jumps, if available. AC_ARG_ENABLE(Bsymbolic, - [AC_HELP_STRING([--disable-Bsymbolic], - [avoid linking with -Bsymbolic])],, + [AS_HELP_STRING([--disable-Bsymbolic],[avoid linking with -Bsymbolic])],, [SAVED_LDFLAGS="${LDFLAGS}" AC_MSG_CHECKING([for -Bsymbolic-functions linker flag]) LDFLAGS=-Wl,-Bsymbolic-functions - AC_TRY_LINK([], [int main (void) { return 0; }], + AC_LINK_IFELSE([AC_LANG_PROGRAM([[]], [[int main (void) { return 0; }]])],[ AC_MSG_RESULT(yes) - enable_Bsymbolic=yes, + enable_Bsymbolic=yes],[ AC_MSG_RESULT(no) - enable_Bsymbolic=no) + enable_Bsymbolic=no]) LDFLAGS="${SAVED_LDFLAGS}"]) @@ -591,9 +837,6 @@ AC_DEFINE_UNQUOTED(GST_DATADIR, "$DATADIR", [data dir]) dnl set location of plugin directory AG_GST_SET_PLUGINDIR -GST_PKG_DEPS="glib-2.0, gobject-2.0, gmodule-no-export-2.0, gthread-2.0" -AC_SUBST(GST_PKG_DEPS) - dnl make sure it doesn't complain about unused variables if debugging is disabled NO_WARNINGS="" if test "x${GST_DISABLE_GST_DEBUG}" = "xyes"; then @@ -603,6 +846,10 @@ fi dnl define an ERROR_CFLAGS Makefile variable AG_GST_SET_ERROR_CFLAGS($FATAL_WARNINGS, [-Wmissing-declarations -Wmissing-prototypes -Wredundant-decls -Wundef -Wwrite-strings -Wformat-nonliteral -Wformat-security -Wold-style-definition -Winit-self -Wmissing-include-dirs -Waddress -Waggregate-return -Wno-multichar -Wnested-externs $NO_WARNINGS]) +dnl special warning flags for gst/printf +AS_COMPILER_FLAG([-Wno-format-nonliteral], [PRINTF_CFLAGS="-Wno-format-nonliteral"]) +AC_SUBST(PRINTF_CFLAGS) + dnl define correct level for debugging messages AG_GST_SET_LEVEL_DEFAULT($GST_GIT) @@ -638,8 +885,8 @@ dnl every flag in GST_OPTION_CFLAGS can be overridden at make time via e.g. dnl make DEPRECATED_CFLAGS='' GST_OPTION_CFLAGS="\$(WARNING_CFLAGS) \$(DEBUG_CFLAGS) \$(PROFILE_CFLAGS) \$(GCOV_CFLAGS) \$(OPT_CFLAGS) \$(DEPRECATED_CFLAGS)" GST_OPTION_CXXFLAGS="\$(WARNING_CXXFLAGS) \$(ERROR_CXXFLAGS) \$(DEBUG_CFLAGS) \$(PROFILE_CFLAGS) \$(GCOV_CFLAGS) \$(OPT_CFLAGS) \$(DEPRECATED_CFLAGS)" -GST_OPTION_CFLAGS="$GST_OPTION_CFLAGS -DGST_USE_UNSTABLE_API" -GST_OPTION_CXXFLAGS="$GST_OPTION_CXXFLAGS -DGST_USE_UNSTABLE_API" +GST_OPTION_CFLAGS="$GST_OPTION_CFLAGS" +GST_OPTION_CXXFLAGS="$GST_OPTION_CXXFLAGS" AC_SUBST(GST_OPTION_CFLAGS) AC_SUBST(GST_OPTION_CXXFLAGS) @@ -680,38 +927,46 @@ dnl default vars for all internal objects built on libgstreamer dnl includes GST_ALL_* GST_OBJ_CFLAGS="\$(GST_ALL_CFLAGS)" GST_OBJ_CXXFLAGS="\$(GST_ALL_CXXFLAGS)" -GST_OBJ_LIBS="\$(top_builddir)/gst/libgstreamer-$GST_MAJORMINOR.la \$(GST_ALL_LIBS)" +GST_OBJ_LIBS="\$(top_builddir)/gst/libgstreamer-$GST_API_VERSION.la \$(GST_ALL_LIBS)" AC_SUBST(GST_OBJ_CFLAGS) AC_SUBST(GST_OBJ_CXXFLAGS) AC_SUBST(GST_OBJ_LIBS) dnl GST_PLUGIN_LDFLAGS dnl LDFLAGS for plugins; includes GST_ALL_LDFLAGS -GST_PLUGIN_LDFLAGS="-module -avoid-version -export-symbols-regex '^[_]*gst_plugin_desc.*' $GST_ALL_LDFLAGS" +GST_PLUGIN_LDFLAGS="-module -avoid-version -export-symbols-regex '^[_]*gst_plugin_.*' $GST_ALL_LDFLAGS" AC_SUBST(GST_PLUGIN_LDFLAGS, "$GST_PLUGIN_LDFLAGS") dnl plugin scanner locations -AS_AC_EXPAND(GST_PLUGIN_SCANNER_INSTALLED,${libexecdir}/gstreamer-$GST_MAJORMINOR/gst-plugin-scanner) +AS_AC_EXPAND(GST_PLUGIN_SCANNER_INSTALLED,${libexecdir}/gstreamer-$GST_API_VERSION/gst-plugin-scanner) AC_DEFINE_UNQUOTED(GST_PLUGIN_SCANNER_INSTALLED, "$GST_PLUGIN_SCANNER_INSTALLED", [location of the installed gst-plugin-scanner]) AC_SUBST(GST_PLUGIN_SCANNER_INSTALLED) +dnl ptp helper locations +AS_AC_EXPAND(GST_PTP_HELPER_INSTALLED,${libexecdir}/gstreamer-$GST_API_VERSION/gst-ptp-helper) +AC_DEFINE_UNQUOTED(GST_PTP_HELPER_INSTALLED, + "$GST_PTP_HELPER_INSTALLED", [location of the installed gst-ptp-helper]) +AC_SUBST(GST_PTP_HELPER_INSTALLED) + dnl things for our internal libcheck (must be called even if building dnl libcheck is disabled because it defines conditionals) AG_GST_CHECK_CHECKS() AC_CONFIG_FILES( Makefile +data/Makefile gst/Makefile gst/gstconfig.h gst/gstversion.h gst/parse/Makefile +gst/printf/Makefile libs/Makefile libs/gst/Makefile libs/gst/base/Makefile libs/gst/check/Makefile libs/gst/check/libcheck/Makefile -libs/gst/check/libcheck/check.h +libs/gst/check/internal-check.h:libs/gst/check/libcheck/check.h.in libs/gst/controller/Makefile libs/gst/helpers/Makefile libs/gst/net/Makefile @@ -727,12 +982,12 @@ tests/examples/adapter/Makefile tests/examples/controller/Makefile tests/examples/stepping/Makefile tests/examples/helloworld/Makefile -tests/examples/launch/Makefile tests/examples/manual/Makefile -tests/examples/metadata/Makefile -tests/examples/queue/Makefile +tests/examples/memory/Makefile +tests/examples/netclock/Makefile +tests/examples/ptp/Makefile +tests/examples/streamiddemux/Makefile tests/examples/streams/Makefile -tests/examples/typefind/Makefile tools/Makefile common/Makefile common/m4/Makefile @@ -761,7 +1016,6 @@ pkgconfig/gstreamer-controller.pc pkgconfig/gstreamer-controller-uninstalled.pc pkgconfig/gstreamer-net.pc pkgconfig/gstreamer-net-uninstalled.pc -gst-element-check.m4 gstreamer.spec ) @@ -773,7 +1027,7 @@ sed \ -e 's/.* GST_DATADIR$/#define GST_DATADIR PREFIX "\\\\share"/' \ -e 's/.* GST_LEVEL_DEFAULT$/#define GST_LEVEL_DEFAULT GST_LEVEL_ERROR/' \ -e 's/.* GST_LICENSE$/#define GST_LICENSE "'$GST_LICENSE'"/' \ - -e 's/.* GST_MAJORMINOR$/#define GST_MAJORMINOR "'$GST_MAJORMINOR'"/' \ + -e 's/.* GST_API_VERSION$/#define GST_API_VERSION "'$GST_API_VERSION'"/' \ -e "s,.* GST_PACKAGE_NAME$,#define GST_PACKAGE_NAME \"${GST_PACKAGE_NAME}\"," \ -e 's/.* GST_PACKAGE_ORIGIN$/#define GST_PACKAGE_ORIGIN "Unknown package origin"/' \ -e "s,.* GST_PACKAGE_RELEASE_DATETIME$,#define GST_PACKAGE_RELEASE_DATETIME \"${GST_PACKAGE_RELEASE_DATETIME}\"," \ @@ -797,7 +1051,7 @@ sed \ -e "s/.* PACKAGE_STRING$/#define PACKAGE_STRING \"$PACKAGE_STRING\"/" \ -e 's/.* PACKAGE_TARNAME$/#define PACKAGE_TARNAME "'$PACKAGE_TARNAME'"/' \ -e 's/.* PACKAGE_VERSION$/#define PACKAGE_VERSION "'$PACKAGE_VERSION'"/' \ - -e 's/.* PLUGINDIR$/#ifdef _DEBUG\n# define PLUGINDIR PREFIX "\\\\debug\\\\lib\\\\gstreamer-0.11"\n#else\n# define PLUGINDIR PREFIX "\\\\lib\\\\gstreamer-0.11"\n#endif/' \ + -e 's/.* PLUGINDIR$/#ifdef _DEBUG\n# define PLUGINDIR PREFIX "\\\\debug\\\\lib\\\\gstreamer-1.0"\n#else\n# define PLUGINDIR PREFIX "\\\\lib\\\\gstreamer-1.0"\n#endif/' \ -e 's/.* GST_PLUGIN_SCANNER_INSTALLED$/#define GST_PLUGIN_SCANNER_INSTALLED LIBDIR "\\\\gst-plugin-scanner"/' \ -e 's/.* VERSION$/#define VERSION "'$VERSION'"/' \ config.h.in >win32/common/config.h-new @@ -833,12 +1087,16 @@ Configuration Allocation tracing : ${enable_alloc_trace} Plugin registry : ${enable_registry} Plugin support : ${enable_plugin} + Static plugins : ${enable_static_plugins} Unit testing support : ${BUILD_CHECK} + PTP clock support : ${HAVE_PTP} Debug : ${USE_DEBUG} Profiling : ${USE_PROFILING} + Building benchmarks : ${BUILD_BENCHMARKS} Building examples : ${BUILD_EXAMPLES} Building test apps : ${BUILD_TESTS} Building tests that fail : ${BUILD_FAILING_TESTS} + Building tools : ${BUILD_TOOLS} "