X-Git-Url: http://review.tizen.org/git/?a=blobdiff_plain;f=autogen.sh;h=4a1a4078f491ea87f9af11aaed4330f142ae1339;hb=6ae04f0e3a26e31a1c1821bf6afe083f11964ddc;hp=336e46d5774135a6cc04859e784bc720d332d7b6;hpb=1756908145a6aa11d79335c2845df8e65e4734a6;p=platform%2Fupstream%2Fgstreamer.git diff --git a/autogen.sh b/autogen.sh index 336e46d..4a1a407 100755 --- a/autogen.sh +++ b/autogen.sh @@ -2,140 +2,104 @@ # Run this to generate all the initial makefiles, etc. DIE=0 -package=GStreamer -srcfile=gst/gstobject.h -#DEBUG=defined -if test "x$1" = "x-d"; then echo "DEBUG output wanted."; DEBUG=defined; fi - -debug () -# print out a debug message if DEBUG is a defined variable -{ - if test ! -z "$DEBUG" - then - echo "DEBUG: $1" +package=gstreamer +srcfile=gst/gst.c + +# a quick cvs co to ease the transition +if test ! -d common; then + if test -f CVS/Tag; then + # get everything from CVS/Tag from second character on + TAG="-r `tail -c +2 CVS/Tag`" fi -} + echo "+ getting common from cvs"; cvs co $TAG common +fi -version_check () -# check the version of a package -# first argument : package name (executable) -# second argument : source download url -# rest of arguments : major, minor, micro version -{ - PACKAGE=$1 - URL=$2 - MAJOR=$3 - MINOR=$4 - MICRO=$5 - - - debug "major $MAJOR minor $MINOR micro $MICRO" - VERSION=$MAJOR - if test ! -z "$MINOR"; then VERSION=$VERSION.$MINOR; else MINOR=0; fi - if test ! -z "$MICRO"; then VERSION=$VERSION.$MICRO; else MICRO=0; fi - - debug "major $MAJOR minor $MINOR micro $MICRO" - echo "Checking for $1 > $VERSION ..." - ($PACKAGE --version) < /dev/null > /dev/null 2>&1 || - { - echo - echo "You must have $PACKAGE installed to compile $package." - echo "Download the appropriate package for your distribution," - echo "or get the source tarball at $URL" - return 1 - } - # the following line is carefully crafted sed magic - pkg_version=`$PACKAGE --version|head -n 1|sed 's/^[a-zA-z\.\ ()]*//;s/ .*$//'` - debug "pkg_version $pkg_version" - pkg_major=`echo $pkg_version | cut -d. -f1` - pkg_minor=`echo $pkg_version | cut -d. -f2` - pkg_micro=`echo $pkg_version | cut -d. -f3` - test -z "$pkg_minor" && pkg_minor=0 - test -z "$pkg_micro" && pkg_micro=0 - - debug "found major $pkg_major minor $pkg_minor micro $pkg_micro" - - #start checking the version - debug "version check" - - if [ "$pkg_major" \< "$MAJOR -o "$pkg_major" = $MAJOR" ]; then - debug "$pkg_major <= $MAJOR" - if [ "$pkg_major" \< "$MAJOR" ]; then - WRONG=1 - elif [ "$pkg_minor" \< "$MINOR -o $pkg_minor = $MINOR" ]; then - if [ "$pkg_minor" \< "$MINOR" ]; then - WRONG=1 - elif [ "$pkg_micro" \< "$MICRO" ]; then - WRONG=1 - fi - fi - fi +# source helper functions +if test ! -f common/gst-autogen.sh; +then + echo There is something wrong with your source tree. + echo You are missing common/gst-autogen.sh + exit 1 +fi +. common/gst-autogen.sh - if test ! -z "$WRONG"; then - echo - echo "You must have $PACKAGE $VERSION or greater to compile $package." - echo "Get the latest version from $URL" - return 1 - fi -} +CONFIGURE_DEF_OPT='--enable-maintainer-mode --enable-plugin-builddir --enable-failing-tests --enable-poisoning' -version_check "autoconf" "ftp://ftp.gnu.org/pub/gnu/autoconf/" 2 52 || DIE=1 -version_check "automake" "ftp://ftp.gnu.org/pub/gnu/automake/" 1 5 || DIE=1 -version_check "libtool" "ftp://ftp.gnu.org/pub/gnu/libtool/" 1 4 0 || DIE=1 -version_check "pkg-config" "http://www.freedesktop.org/software/pkgconfig" 0 7 0 || DIE=1 +autogen_options $@ -if test "$DIE" -eq 1; then - exit 1 -fi +echo -n "+ check for build tools" +if test ! -z "$NOCHECK"; then echo ": skipped version checks"; else echo; fi +version_check "autoconf" "$AUTOCONF autoconf autoconf-2.54 autoconf-2.53 autoconf-2.52" \ + "ftp://ftp.gnu.org/pub/gnu/autoconf/" 2 52 || DIE=1 +version_check "automake" "$AUTOMAKE automake automake-1.7 automake17 automake-1.6" \ + "ftp://ftp.gnu.org/pub/gnu/automake/" 1 6 || DIE=1 +version_check "autopoint" "autopoint" \ + "ftp://ftp.gnu.org/pub/gnu/gettext/" 0 11 4 || DIE=1 +version_check "libtoolize" "libtoolize libtoolize14" \ + "ftp://ftp.gnu.org/pub/gnu/libtool/" 1 4 0 || DIE=1 +version_check "pkg-config" "" \ + "http://www.freedesktop.org/software/pkgconfig" 0 8 0 || DIE=1 -test -f $srcfile || { - echo "You must run this script in the top-level $package directory" - exit 1 -} +die_check $DIE + +autoconf_2_52d_check || DIE=1 +aclocal_check || DIE=1 +autoheader_check || DIE=1 +die_check $DIE + +# if no arguments specified then this will be printed if test -z "$*"; then - echo "I am going to run ./configure with no arguments - if you wish " - echo "to pass any to it, please specify them on the $0 command line." + echo "+ checking for autogen.sh options" + echo " This autogen script will automatically run ./configure as:" + echo " ./configure $CONFIGURE_DEF_OPT" + echo " To pass any additional options, please specify them on the $0" + echo " command line." fi +toplevel_check $srcfile -libtoolize --copy --force -aclocal $ACLOCAL_FLAGS || { - echo - echo "aclocal failed - check that all needed development files are present on system" - exit 1 -} -autoheader || { - echo - echo "autoheader failed" - exit 1 -} -autoconf || { - echo - echo "autoconf failed" - #exit 1 -} -automake --add-missing || { - echo - echo "automake failed" - #exit 1 -} +# autopoint +# older autopoint (< 0.12) has a tendency to complain about mkinstalldirs +if test -e mkinstalldirs; then rm mkinstalldirs; fi +# first remove patch if necessary, then run autopoint, then reapply +if test -f po/Makefile.in.in; +then + patch -p0 -R < common/gettext.patch +fi +tool_run "$autopoint --force" +patch -p0 < common/gettext.patch -# now remove the cache, because it can be considered dangerous in this case -rm -f config.cache +# aclocal +if test -f acinclude.m4; then rm acinclude.m4; fi +tool_run "$aclocal" "-I common/m4 $ACLOCAL_FLAGS" -CONFIGURE_OPT='--enable-maintainer-mode --enable-plugin-builddir --enable-debug --enable-DEBUG' +tool_run "$libtoolize" "--force" +tool_run "$autoheader" -echo -echo "./configure default flags: $CONFIGURE_OPT" -echo "using: $CONFIGURE_OPT $@" +# touch the stamp-h.in build stamp so we don't re-run autoheader in maintainer mode -- wingo +echo timestamp > stamp-h.in 2> /dev/null + +tool_run "$autoconf" +debug "automake: $automake" +tool_run "$automake" "-a -c" + +test -n "$NOCONFIGURE" && { + echo "skipping configure stage for package $package, as requested." + echo "autogen.sh done." + exit 0 +} + +echo "+ running configure ... " +test ! -z "$CONFIGURE_DEF_OPT" && echo " ./configure default flags: $CONFIGURE_DEF_OPT" +test ! -z "$CONFIGURE_EXT_OPT" && echo " ./configure external flags: $CONFIGURE_EXT_OPT" echo -./configure $CONFIGURE_OPT "$@" || { - echo - echo "configure failed" - exit 1 +echo ./configure $CONFIGURE_DEF_OPT $CONFIGURE_EXT_OPT +./configure $CONFIGURE_DEF_OPT $CONFIGURE_EXT_OPT || { + echo " configure failed" + exit 1 } -echo echo "Now type 'make' to compile $package." +