]> git.sesse.net Git - vlc/blobdiff - extras/contrib/bootstrap
* prefer wget over curl
[vlc] / extras / contrib / bootstrap
index a916b278a2920a08e9d7f3ae63a68e6a5f6840d6..5db7080da1664be3f0762e67117fe0372b67d0b4 100755 (executable)
@@ -24,9 +24,9 @@
 # Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston MA 02110-1301, USA.
 # ***************************************************************************
 
-if test "$#" -gt "1"; then
-  echo "Usage: $0 <host>" >&2
-  echo "  Prepare config.mak file." >&2
+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
 fi
 
@@ -36,18 +36,31 @@ set -e
 set -x
 
 BUILD=`gcc -dumpmachine`
-if test "$#" = "1"; then
+if test "$#" -ge "1"; then
   HOST="$1"
 else
   HOST="$BUILD"
 fi
 
+DISTRO=
+if test "$#" = "2"; then
+    echo "Forcing distro.mak to use $2.mak"
+    DISTRO="$2"
+    HOST="$1"
+fi
+
 rm -f config.mak
 {
-       echo "# Automatically generated by bootstrap."
-       echo "# Make changes if you know what you're doing."
+    echo "# Automatically generated by bootstrap."
+    echo "# Make changes if you know what you're doing."
 } > config.mak
 
+rm -f distro.mak
+{
+    echo "# Automatically generated by bootstrap"
+    echo "# Make changes if you know what you're doing."
+} > distro.mak
+
 if test "$HOST" != "$BUILD"; then
     CC="${HOST}-gcc"
     CXX="${HOST}-g++"
@@ -56,41 +69,84 @@ if test "$HOST" != "$BUILD"; then
     AR="${HOST}-ar"
 fi
 
+# Check the HAVE_{OS}
+case $HOST in
+    *darwin*)
+        echo "HAVE_DARWIN_OS = 1" >> config.mak
+        echo "HAVE_BSD = 1" >> config.mak
+    ;;
+    *linux*)
+        echo "HAVE_LINUX = 1" >> config.mak
+    ;;
+    *bsd*)
+        echo "HAVE_BSD = 1" >> config.mak
+    ;;
+    *wince*)
+        echo "HAVE_WINCE = 1" >> config.mak
+    ;;
+    *beos*)
+        echo "HAVE_BEOS = 1" >> config.mak
+    ;;
+esac
+
 case $HOST in
     ppc-darwin)
 # Mac OS X < 10.4
-           echo "Your version of Mac OS X is too old!" >&2
-           echo "Compiling VLC requires 10.4.x or later" >&2
-           exit 1
-       ;;
+        echo "Your version of Mac OS X is too old!" >&2
+        echo "Compiling VLC requires 10.4.x or later" >&2
+        exit 1
+    ;;
     powerpc-apple-darwin8)
 # Mac OS X 10.4
 # 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.3
-           echo "SDK_TARGET = ${SDK_TARGET}" >> config.mak
-           echo "HAVE_DARWIN_OS = 1" >> config.mak
-           echo "ENVP = MACOSX_DEPLOYMENT_TARGET=${SDK_TARGET}" >> config.mak
-           echo "MACOSX_SDK = /Developer/SDKs/MacOSX10.3.9.sdk" >> config.mak
-           CFLAGS_TUNING=" -arch ppc -mtune=G4"
-           EXTRA_CFLAGS=" -D\${ENVP} -isysroot \${MACOSX_SDK}"
-           EXTRA_LDFLAGS=" -isysroot \${MACOSX_SDK} -Wl,-syslibroot,\${MACOSX_SDK}"
-           echo "PATH = /bin:/usr/bin:/usr/local/bin" >> config.mak
+        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
+        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
+        cat src/Distributions/darwin.mak >> distro.mak
         ;;
     i686-apple-darwin8)
-           SDK_TARGET=10.4
-           echo "SDK_TARGET = ${SDK_TARGET}" >> config.mak
-           echo "HAVE_DARWIN_OS = 1" >> config.mak
-           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}"
-           EXTRA_LDFLAGS=" -isysroot \${MACOSX_SDK} -Wl,-syslibroot,\${MACOSX_SDK}"
-           echo "PATH = /bin:/usr/bin:/usr/local/bin" >> config.mak
+        SDK_TARGET=10.4
+        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
+        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
+        ;;
+    powerpc-apple-darwin9)
+        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
+        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
+        cat src/Distributions/darwin.mak >> distro.mak
+        ;;
+    i686-apple-darwin9)
+        SDK_TARGET=10.4
+        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
+        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
         ;;
     i586-pc-beos)
-            echo "HAVE_BEOS = 1" >> config.mak
             if test -f /boot/beos/system/lib/libbind.so; then
                 EXTRA_LDFLAGS=" -lbind -lsocket"
             else
@@ -112,13 +168,16 @@ case $HOST in
                 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
         ;;
     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`
@@ -126,13 +185,46 @@ case $HOST in
             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 "HAVE_WINCE = 1" >> config.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
+            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
         ;;
 esac
 
@@ -147,17 +239,17 @@ echo "LD = ${LD}" >> config.mak
 echo "RANLIB = ${RANLIB}" >> config.mak
 echo "AR = ${AR}" >> config.mak
 echo "EXTRA_CFLAGS = ${CFLAGS_TUNING} ${EXTRA_CFLAGS}" >> config.mak
-echo "EXTRA_CPPFLAGS = ${EXTRA_CPPFLAGS} -I${PREFIX}/include" >> 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 which curl >/dev/null; then
-       echo "WGET = curl -O" >> config.mak
-elif wget --version >/dev/null 2>&1; then
-       echo "WGET = wget" >> config.mak
+if which wget --version >/dev/null 2>&1; then
+    echo "WGET = wget -c" >> config.mak
+elif curl >/dev/null; then
+    echo "WGET = curl -L -O" >> config.mak
 else
-       echo "You need at least wget or curl to fetch the packages." >&2
-       exit 1
+    echo "You need at least wget or curl to fetch the packages." >&2
+    exit 1
 fi
 
 if test -f /sw/bin/svn; then
@@ -165,9 +257,9 @@ if test -f /sw/bin/svn; then
 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
+    echo "SVN = /usr/bin/svn" >> config.mak
 elif test -f /opt/local/bin/svn; then
-       echo "SVN = /opt/local/bin/svn" >> config.mak
+    echo "SVN = /opt/local/bin/svn" >> config.mak
 elif svn help >/dev/null 2>&1; then
         echo "SVN = svn" >> config.mak
 else