]> git.sesse.net Git - vlc/blobdiff - extras/contrib/bootstrap
libvlccore: fix AUTO_ADJUST_PTS_DELAY short comment.
[vlc] / extras / contrib / bootstrap
index 3fa6abe541496295077aeed0cbd6392dd7389975..0fcb9e531018039a852edd779d3ad082715f2318 100755 (executable)
@@ -25,9 +25,9 @@
 # ***************************************************************************
 
 if test "$#" -gt "2" -o "$1" = "-h" -o "$1" = "--help" ; then
-  echo "Usage: $0 [host [distro]]" >&2
-  echo "  Prepare config.mak and distro.mak file." >&2
-  exit 1
+    echo "Usage: $0 [host [distro]]" >&2
+    echo "  Prepare config.mak and distro.mak file." >&2
+    exit 1
 fi
 
 LANG=C
@@ -37,9 +37,9 @@ set -x
 
 BUILD=`gcc -dumpmachine`
 if test "$#" -ge "1"; then
-  HOST="$1"
+    HOST="$1"
 else
-  HOST="$BUILD"
+    HOST="$BUILD"
 fi
 
 DISTRO=
@@ -67,6 +67,7 @@ if test "$HOST" != "$BUILD"; then
     LD="${HOST}-ld"
     RANLIB="${HOST}-ranlib"
     AR="${HOST}-ar"
+    STRIP="${HOST}-strip"
 fi
 
 # Check the HAVE_{OS}
@@ -97,10 +98,9 @@ case $HOST in
         exit 1
     ;;
     powerpc-apple-darwin8)
-# Mac OS X 10.4
+# Mac OS X 10.4 or 10.5 with Xcode 2.5
 # Makefile cross compiling is only supported with gcc-4.0
 # ENVP defines the oldest environment on which the program will be able to run
-# SDK 10.2.8 requires gcc-3.3 (so we cannot use that SDK)
         SDK_TARGET=10.4
         echo "SDK_TARGET = ${SDK_TARGET}" >> config.mak
         echo "ENVP = MACOSX_DEPLOYMENT_TARGET=${SDK_TARGET}" >> config.mak
@@ -112,7 +112,7 @@ case $HOST in
         LD="ld -arch ppc -syslibroot \${MACOSX_SDK}"
         echo "PATH = /bin:/usr/bin:/usr/local/bin" >> config.mak
         cat src/Distributions/darwin.mak >> distro.mak
-        ;;
+    ;;
     i686-apple-darwin8)
         SDK_TARGET=10.4
         echo "SDK_TARGET = ${SDK_TARGET}" >> config.mak
@@ -124,110 +124,153 @@ case $HOST in
         EXTRA_LDFLAGS=" -isysroot \${MACOSX_SDK} -Wl,-syslibroot,\${MACOSX_SDK}"
         echo "PATH = /bin:/usr/bin:/usr/local/bin" >> config.mak
         cat src/Distributions/darwin.mak >> distro.mak
-        ;;
+    ;;
     powerpc-apple-darwin9)
+# Mac OS X 10.5 with Xcode 3, specific rules apply
         SDK_TARGET=10.4
         echo "SDK_TARGET = ${SDK_TARGET}" >> config.mak
-#        echo "ENVP = MACOSX_DEPLOYMENT_TARGET=${SDK_TARGET}" >> config.mak
-#        echo "MACOSX_SDK = /Developer/SDKs/MacOSX10.4u.sdk" >> config.mak
+        echo "ENVP = MACOSX_DEPLOYMENT_TARGET=${SDK_TARGET}" >> config.mak
+        echo "MACOSX_SDK = /Developer/SDKs/MacOSX10.4u.sdk" >> config.mak
+        echo "HAVE_DARWIN_9 = 1" >> config.mak
         CFLAGS_TUNING=" -arch ppc -mtune=G4"
-#        EXTRA_CFLAGS=" -D\${ENVP} -isysroot \${MACOSX_SDK} -mmacosx-version-min=\${SDK_TARGET}"
-#        EXTRA_LDFLAGS=" -isysroot \${MACOSX_SDK} -Wl,-syslibroot,\${MACOSX_SDK}"
-        echo "PATH = /bin:/usr/bin:/usr/local/bin" >> config.mak
+        EXTRA_CFLAGS=" -D\${ENVP} -mmacosx-version-min=\${SDK_TARGET}"
+        CC="gcc -isysroot \${MACOSX_SDK}"
+        CXX="g++ -isysroot \${MACOSX_SDK}"
+        LD="ld -arch ppc -syslibroot \${MACOSX_SDK}"
+        echo "PATH = /bin:/usr/bin:/usr/local/bin:" >> config.mak
         cat src/Distributions/darwin.mak >> distro.mak
-        ;;
+        if test -e /Developer/SDKs; then
+            echo "SDKs found. Everything is fine." >&2
+        else
+            echo "ERROR:\nYour Developer Tools' SDKs were not found.\nYou need to add extra symbolic links to /Developer to achieve correctly\nbuilt contribs.\nHave a look at the OSX-Compile-HOWTO for details." >&2
+            exit 1
+        fi
+    ;;
     i686-apple-darwin9)
         SDK_TARGET=10.4
+        MIN_LD_VERSION_WITH_TEXT_RELOCATION=81
         echo "SDK_TARGET = ${SDK_TARGET}" >> config.mak
         echo "HAVE_DARWIN_OS_ON_INTEL = 1" >> config.mak
-#        echo "ENVP = MACOSX_DEPLOYMENT_TARGET=${SDK_TARGET}" >> config.mak
-#        echo "MACOSX_SDK = /Developer/SDKs/MacOSX10.4u.sdk" >> config.mak
+        echo "HAVE_DARWIN_9 = 1" >> config.mak
+        if test `ld -v 2> /dev/stdout | sed -E 's/.*ld64-([0-9]+).*/\1/'` -lt ${MIN_LD_VERSION_WITH_TEXT_RELOCATION}; then
+            echo "NO_TEXT_RELOCATION = 1" >> config.mak
+        fi
+        echo "ENVP = MACOSX_DEPLOYMENT_TARGET=${SDK_TARGET}" >> config.mak
+        echo "MACOSX_SDK = /Developer/SDKs/MacOSX10.4u.sdk" >> config.mak
         CFLAGS_TUNING=" -march=pentium-m -mtune=prescott"
-#        EXTRA_CFLAGS=" -D\${ENVP} -isysroot \${MACOSX_SDK} -mmacosx-version-min=\${SDK_TARGET}"
-#        EXTRA_LDFLAGS=" -isysroot \${MACOSX_SDK} -Wl,-syslibroot,\${MACOSX_SDK}"
+        EXTRA_CFLAGS=" -D\${ENVP} -isysroot \${MACOSX_SDK} -mmacosx-version-min=\${SDK_TARGET}"
+        EXTRA_LDFLAGS=" -isysroot \${MACOSX_SDK} -Wl,-syslibroot,\${MACOSX_SDK}"
         echo "PATH = /bin:/usr/bin:/usr/local/bin" >> config.mak
         cat src/Distributions/darwin.mak >> distro.mak
-        ;;
+        if test -e /Developer/SDKs; then
+            echo "SDKs found. Everything is fine." >&2
+        else
+            echo "ERROR:\nYour Developer Tools' SDKs were not found.\nYou need to add extra symbolic links to /Developer to achieve correctly\nbuilt contribs.\nHave a look at the OSX-Compile-HOWTO for details." >&2
+            exit 1
+        fi
+    ;;
+    i686-apple-darwin10d1)
+        SDK_TARGET=10.6
+        echo "SDK_TARGET = ${SDK_TARGET}" >> config.mak
+        echo "HAVE_DARWIN_OS_ON_INTEL = 1" >> config.mak
+        echo "HAVE_DARWIN_9 = 1" >> config.mak
+        echo "HAVE_DARWIN_10 = 1" >> config.mak
+        echo "ENVP = MACOSX_DEPLOYMENT_TARGET=${SDK_TARGET}" >> config.mak
+        echo "MACOSX_SDK = /Developer/SDKs/MacOSX10.6.sdk" >> config.mak
+        CFLAGS_TUNING=" -march=pentium-m -mtune=prescott"
+        EXTRA_CFLAGS=" -D\${ENVP} -isysroot \${MACOSX_SDK} -mmacosx-version-min=\${SDK_TARGET}"
+        EXTRA_LDFLAGS=" -isysroot \${MACOSX_SDK} -Wl,-syslibroot,\${MACOSX_SDK}"
+        echo "PATH = /bin:/usr/bin:/usr/local/bin" >> config.mak
+        cat src/Distributions/darwin.mak >> distro.mak
+        if test -e /Developer/SDKs; then
+            echo "SDKs found. Everything is fine." >&2
+        else
+            echo "ERROR:\nYour Developer Tools' SDKs were not found.\nYou need to add extra symbolic links to /Developer to achieve correctly\nbuilt contribs.\nHave a look at the OSX-Compile-HOWTO for details." >&2
+            exit 1
+        fi
+    ;;
     i586-pc-beos)
-            if test -f /boot/beos/system/lib/libbind.so; then
-                EXTRA_LDFLAGS=" -lbind -lsocket"
-            else
-                EXTRA_LDFLAGS=" -lnet"
-            fi
-            if test "$HOST" = "$BUILD"; then
-#               Compiling on BeOS
-                PATH=".:/boot/home/config/bin:/bin:/boot/apps"
-                PATH="${PATH}:/boot/preferences:/boot/beos/apps"
-                PATH="${PATH}:/boot/beos/preferences"
-                PATH="${PATH}:/boot/develop/tools/gnupro/bin"
-                echo "PATH = ${PATH}" >> config.mak
-                LIBRARY_PATH="${LIBRARY_PATH}:%A/lib:/boot/home/config/lib"
-                LIBRARY_PATH="${LIBRARY_PATH}:/boot/beos/system/lib"
-                echo "LIBRARY_PATH = ${LIBRARY_PATH}" >> config.mak
-            else
-#               Cross compiling from Linux
-                PATH="/opt/beos-tools/bin:/opt/cross-tools/bin"
-                PATH="${PATH}:/usr/bin:/bin"
-                echo "PATH = ${PATH}" >> config.mak
-            fi
-            cat src/Distributions/beos.mak >> distro.mak
-        ;;
+        if test -f /boot/beos/system/lib/libbind.so; then
+            EXTRA_LDFLAGS=" -lbind -lsocket"
+        else
+            EXTRA_LDFLAGS=" -lnet"
+        fi
+        if test "$HOST" = "$BUILD"; then
+#           Compiling on BeOS
+            PATH=".:/boot/home/config/bin:/bin:/boot/apps"
+            PATH="${PATH}:/boot/preferences:/boot/beos/apps"
+            PATH="${PATH}:/boot/beos/preferences"
+            PATH="${PATH}:/boot/develop/tools/gnupro/bin"
+            echo "PATH = ${PATH}" >> config.mak
+            LIBRARY_PATH="${LIBRARY_PATH}:%A/lib:/boot/home/config/lib"
+            LIBRARY_PATH="${LIBRARY_PATH}:/boot/beos/system/lib"
+            echo "LIBRARY_PATH = ${LIBRARY_PATH}" >> config.mak
+        else
+#           Cross compiling from Linux
+            PATH="/opt/beos-tools/bin:/opt/cross-tools/bin"
+            PATH="${PATH}:/usr/bin:/bin"
+            echo "PATH = ${PATH}" >> config.mak
+        fi
+        cat src/Distributions/beos.mak >> distro.mak
+    ;;
     *mingw32*)
-            echo "HAVE_WIN32 = 1" >> config.mak
-            echo "PKG_CONFIG_PATH = \$(PREFIX)/lib/pkgconfig" >> config.mak
-            cat src/Distributions/win32.mak >> distro.mak
-        ;;
+        echo "HAVE_WIN32 = 1" >> config.mak
+        echo "PKG_CONFIG_PATH = \$(PREFIX)/lib/pkgconfig" >> config.mak
+           EXTRA_CFLAGS="-O3"
+        cat src/Distributions/win32.mak >> distro.mak
+    ;;
     i686-pc-cygwin)
-            echo "HAVE_WIN32 = 1" >> config.mak
-            echo "HAVE_CYGWIN = 1" >> config.mak
-            CC="gcc -mno-cygwin -isystem /usr/include/mingw"
-            CXX="g++ -mno-cygwin -isystem /usr/include/mingw"
-            HOST=`$CC -dumpmachine`
-            EXTRA_CFLAGS=" -mno-cygwin -isystem /usr/include/mingw"
-            EXTRA_CPPFLAGS=" -mno-cygwin -isystem /usr/include/mingw"
-            EXTRA_LDFLAGS=" -mno-cygwin"
-            echo "PKG_CONFIG_PATH = \$(PREFIX)/lib/pkgconfig" >> config.mak
-            cat src/Distributions/win32.mak >> distro.mak
-        ;;
+        echo "HAVE_WIN32 = 1" >> config.mak
+        echo "HAVE_CYGWIN = 1" >> config.mak
+        CC="gcc -mno-cygwin -isystem /usr/include/mingw"
+        CXX="g++ -mno-cygwin -isystem /usr/include/mingw"
+        HOST=`$CC -dumpmachine`
+        EXTRA_CFLAGS=" -mno-cygwin -isystem /usr/include/mingw"
+        EXTRA_CPPFLAGS=" -mno-cygwin -isystem /usr/include/mingw"
+        EXTRA_LDFLAGS=" -mno-cygwin"
+        echo "PKG_CONFIG_PATH = \$(PREFIX)/lib/pkgconfig" >> config.mak
+        cat src/Distributions/win32.mak >> distro.mak
+    ;;
     arm-wince-pe)
-            echo "PKG_CONFIG_PATH = \$(PREFIX)/lib/pkgconfig" >> config.mak
-            EXTRA_CPPFLAGS=" -D_WIN32_WCE"
-            cat src/Distributions/wince.mak >> distro.mak
-        ;;
+        echo "PKG_CONFIG_PATH = \$(PREFIX)/lib/pkgconfig" >> config.mak
+        EXTRA_CPPFLAGS=" -D_WIN32_WCE"
+        cat src/Distributions/wince.mak >> distro.mak
+    ;;
     armeb-linux-uclibc)
-            echo "HAVE_UCLIBC = 1" >> config.mak
-            echo "HAVE_BIGENDIAN = 1" >> config.mak
+        echo "HAVE_UCLIBC = 1" >> config.mak
+        echo "HAVE_BIGENDIAN = 1" >> config.mak
+        EXTRA_CFLAGS="-Os -march=armv5 -msoft-float"
+        if test ! -z "${DISTRO}";  then
+            cat src/Distributions/${DISTRO}.mak >> distro.mak
+        else
+            cat src/Distributions/unix.mak >> distro.mak
+        fi
+    ;;
+    *)
+        if test "$HOST" = "$BUILD"; then
+            if test -d "/usr/lib/pkgconfig"; then
+                if test -z "$PKG_CONFIG_PATH"; then
+                    echo "PKG_CONFIG_PATH = /usr/lib/pkgconfig" >> config.mak
+                fi
+                if test -z "$PKG_CONFIG_LIBDIR"; then
+                    echo "PKG_CONFIG_LIBDIR = /usr/lib/pkgconfig" >> config.mak
+                fi
+            fi
+            # Try to match distribution
+            if test -f /etc/fedora-release; then
+                cat src/Distributions/fedora.mak >> distro.mak
+            else
+                # Default Unix-like systems
+                cat src/Distributions/unix.mak >> distro.mak
+            fi
+        else # unknown distro
             if test ! -z "${DISTRO}";  then
                 cat src/Distributions/${DISTRO}.mak >> distro.mak
             else
                 cat src/Distributions/unix.mak >> distro.mak
             fi
-        ;;
-    *)
-            if test "$HOST" = "$BUILD"; then
-                if test -d "/usr/lib/pkgconfig"; then
-                    if test -z "$PKG_CONFIG_PATH"; then
-                        echo "PKG_CONFIG_PATH = /usr/lib/pkgconfig" >> config.mak
-                    fi
-                    if test -z "$PKG_CONFIG_LIBDIR"; then
-                        echo "PKG_CONFIG_LIBDIR = /usr/lib/pkgconfig" >> config.mak
-                    fi
-                fi
-                # Try to match distribution
-                if test -f /etc/fedora-release; then
-                    cat src/Distributions/fedora.mak >> distro.mak
-                else
-                    # Default Unix-like systems
-                    cat src/Distributions/unix.mak >> distro.mak
-                fi
-            else # unknown distro
-                if test ! -z "${DISTRO}";  then
-                    cat src/Distributions/${DISTRO}.mak >> distro.mak
-                else
-                    cat src/Distributions/unix.mak >> distro.mak
-                fi
-            fi
-        ;;
+        fi
+    ;;
 esac
 
 echo "BUILD = $BUILD" >> config.mak
@@ -240,30 +283,40 @@ echo "CXX = ${CXX}" >> config.mak
 echo "LD = ${LD}" >> config.mak
 echo "RANLIB = ${RANLIB}" >> config.mak
 echo "AR = ${AR}" >> config.mak
+echo "STRIP = ${STRIP}" >> config.mak
 echo "EXTRA_CFLAGS = ${CFLAGS_TUNING} ${EXTRA_CFLAGS}" >> config.mak
 echo "EXTRA_CPPFLAGS = ${EXTRA_CPPFLAGS} -isystem \$(PREFIX)/include" >> config.mak
 echo "EXTRA_LDFLAGS = ${EXTRA_LDFLAGS}" >> config.mak
 echo "EXTRA_PATH = ${EXTRA_PATH}" >> config.mak
 
 if wget --version >/dev/null 2>&1; then
-    echo "WGET = `which wget` -c" >> config.mak
-elif which curl >/dev/null; then
+    echo "WGET = `which wget` -c --passive" >> config.mak
+elif test -z `curl --version >/dev/null 2>&1`; then
     echo "WGET = `which curl` -L -O" >> config.mak
 else
     echo "You need at least wget or curl to fetch the packages." >&2
     exit 1
 fi
 
-if test -f /sw/bin/svn; then
-        echo "SVN = /sw/bin/svn" >> config.mak
-elif test -f /usr/local/bin/svn; then
-        echo "SVN = /usr/local/bin/svn" >> config.mak
-elif test -f /usr/bin/svn; then
-    echo "SVN = /usr/bin/svn" >> config.mak
-elif test -f /opt/local/bin/svn; then
-    echo "SVN = /opt/local/bin/svn" >> config.mak
-elif svn help >/dev/null 2>&1; then
-        echo "SVN = `which svn`" >> config.mak
+if svn --version >/dev/null 2>&1; then
+    echo "SVN = `which svn`" >> config.mak
+else
+    echo "You do not have a subversion client in your PATH." >&2
+fi
+
+if git --version>/dev/null 2>&1; then
+    echo "GIT = `which git`" >> config.mak
+else
+    echo "You do not have a Git client in your PATH." >&2
+fi
+
+if test -z "$CONTRIBS_RELEASE"; then
+    set +x
+    echo
+    echo "***********************************************************"
+    echo "* If you are building contribs for a release build of VLC *"
+    echo "* Please run CONTRIBS_RELEASE=sexy ./bootstrap            *"
+    echo "***********************************************************"
 else
-        echo "You do not have a subversion client installed." >&2
+    echo "EXTRA_CFLAGS += -DNDEBUG" >> config.mak
 fi