X-Git-Url: https://git.sesse.net/?a=blobdiff_plain;f=contrib%2Fbootstrap;h=b8d88c9b85b2779b11c9fc41633f501e5311f7b6;hb=6e85f629f04625c7ff5d42e522ad931120061867;hp=231d09b7f6de2157178d9566f814e6f2c60a67bd;hpb=3aa1cecf483a52300e69bbbc897a1f9384190030;p=vlc diff --git a/contrib/bootstrap b/contrib/bootstrap index 231d09b7f6..b8d88c9b85 100755 --- a/contrib/bootstrap +++ b/contrib/bootstrap @@ -24,13 +24,22 @@ usage() echo " --build=BUILD configure for building on BUILD" echo " --host=HOST cross-compile to build to run on HOST" echo " --prefix=PREFIX install files in PREFIX" + echo " --disable-FOO configure to not build package FOO" + echo " --enable-FOO configure to build package FOO" + echo " --disable-disc configure to not build optical discs packages" + echo " --disable-sout configure to not build stream output packages" + echo " --enable-small optimize libraries for size with slight speed decrease [DANGEROUS]" } BUILD= HOST= PREFIX= +PKGS_ENABLE= +PKGS_DISABLE= +BUILD_ENCODERS="1" +BUILD_DISCS="1" -if test ! -f "../src/main.mak" +if test ! -f "../../contrib/src/main.mak" then echo "$0 must be run from a subdirectory" exit 1 @@ -52,6 +61,21 @@ do --prefix=*) PREFIX="${1#--prefix=}" ;; + --disable-disc) + BUILD_DISCS= + ;; + --disable-sout) + BUILD_ENCODERS= + ;; + --enable-small) + ENABLE_SMALL=1 + ;; + --disable-*) + PKGS_DISABLE="${PKGS_DISABLE} ${1#--disable-}" + ;; + --enable-*) + PKGS_ENABLE="${PKGS_ENABLE} ${1#--enable-}" + ;; *) echo "Unrecognized options $1" usage @@ -83,17 +107,11 @@ if test "$PREFIX" then # strip trailing slash PREFIX="${PREFIX%/}" -else - PREFIX="../hosts/$HOST" fi # # Prepare files # -echo "Creating prefix... $PREFIX" -mkdir -p -- "$PREFIX" || exit $? -mkdir -p -- "$PREFIX/share/aclocal" || exit $? - echo "Creating configuration file... config.mak" exec 3>config.mak cat >&3 << EOF @@ -101,7 +119,8 @@ cat >&3 << EOF # Any change will be overwritten if ../bootstrap is run again. BUILD := $BUILD HOST := $HOST -PREFIX := $PREFIX +PKGS_DISABLE := $PKGS_DISABLE +PKGS_ENABLE := $PKGS_ENABLE EOF add_make() @@ -122,47 +141,129 @@ add_make_enabled() done } +check_macosx_sdk() +{ + [ -z "${OSX_VERSION}" ] && echo "OSX_VERSION not specified, assuming 10.7" && OSX_VERSION=10.7 + if test -z "$SDKROOT" + then + SDKROOT=`xcode-select -print-path`/Platforms/MacOSX.platform/Developer/SDKs/MacOSX$OSX_VERSION.sdk + echo "SDKROOT not specified, assuming $SDKROOT" + fi + + if [ ! -d "${SDKROOT}" ] + then + SDKROOT_NOT_FOUND=`xcode-select -print-path`/Platforms/MacOSX.platform/Developer/SDKs/MacOSX$OSX_VERSION.sdk + SDKROOT=`xcode-select -print-path`/SDKs/MacOSX$OSX_VERSION.sdk + echo "SDKROOT not found at $SDKROOT_NOT_FOUND, trying $SDKROOT" + fi + + if [ ! -d "${SDKROOT}" ] + then + echo "*** ${SDKROOT} does not exist, please install required SDK, or set SDKROOT manually. ***" + exit 1 + fi + + add_make "MACOSX_SDK=${SDKROOT}" + add_make "OSX_VERSION ?= ${OSX_VERSION}" +} + +check_ios_sdk() +{ + if test -z "$SDKROOT" + then + SDKROOT=`xcode-select -print-path`/Platforms/iPhone${PLATFORM}.platform/Developer/SDKs/iPhone${PLATFORM}${SDK_VERSION}.sdk + echo "SDKROOT not specified, assuming $SDKROOT" + else + SDKROOT="$SDKROOT" + fi + + if [ ! -d "${SDKROOT}" ] + then + echo "*** ${SDKROOT} does not exist, please install required SDK, or set SDKROOT manually. ***" + exit 1 + fi + add_make "SDKROOT=${SDKROOT}" +} + +check_android_sdk() +{ + [ -z "${ANDROID_NDK}" ] && echo "You must set ANDROID_NDK environment variable" && exit 1 + add_make "ANDROID_NDK := ${ANDROID_NDK}" + [ -z "${ANDROID_ABI}" ] && echo "You must set ANDROID_ABI environment variable" && exit 1 + add_make "ANDROID_ABI := ${ANDROID_ABI}" + [ ${ANDROID_ABI} = "armeabi-v7a" ] && add_make_enabled "HAVE_NEON" + [ ${ANDROID_ABI} = "armeabi-v7a" ] && add_make_enabled "HAVE_ARMV7A" +} + +test -z "$PREFIX" || add_make "PREFIX := $PREFIX" +test -z "$BUILD_DISCS" || add_make_enabled "BUILD_DISCS" +test -z "$BUILD_ENCODERS" || add_make_enabled "BUILD_ENCODERS" +test -z "$ENABLE_SMALL" || add_make_enabled "ENABLE_SMALL" + # # Checks # OS="${HOST#*-}" # strip architecture case "${OS}" in - *darwin*) - add_make_enabled "HAVE_DARWIN_OS" "HAVE_BSD" + apple-darwin*) + if test -z "$BUILDFORIOS" + then + check_macosx_sdk + add_make_enabled "HAVE_MACOSX" "HAVE_DARWIN_OS" "HAVE_BSD" + else + check_ios_sdk + add_make_enabled "HAVE_IOS" "HAVE_DARWIN_OS" "HAVE_BSD" "HAVE_NEON" "HAVE_ARMV7A" + fi ;; *bsd*) add_make_enabled "HAVE_BSD" ;; + *android*) + check_android_sdk + add_make_enabled "HAVE_LINUX" "HAVE_ANDROID" + case "${HOST}" in + *arm*) + add_make "PLATFORM_SHORT_ARCH := arm" + ;; + *i686*) + add_make "PLATFORM_SHORT_ARCH := x86" + ;; + *mipsel*) + add_make "PLATFORM_SHORT_ARCH := mips" + ;; + esac + ;; *linux*) add_make_enabled "HAVE_LINUX" ;; - *mingw*) - add_make_enabled "HAVE_WIN32" - ;; *wince*) add_make_enabled "HAVE_WINCE" ;; + *mingw*) + add_make_enabled "HAVE_WIN32" + ;; esac - # # Results output # test -e Makefile && unlink Makefile -ln -sf ../src/main.mak Makefile +ln -sf ../../contrib/src/main.mak Makefile cat << EOF Bootstrap completed. -The following packages were selected: -$PKGS - Run "make" to start compilation. Other targets: * make install same as "make" + * make prebuilt fetch and install prebuilt binaries + * make list list packages * make fetch fetch required source tarballs * make fetch-all fetch all source tarballs * make distclean clean everything and undo bootstrap - * make clean clean everything * make mostlyclean clean everything except source tarballs + * make clean clean everything + * make package prepare prebuilt packages EOF + +mkdir -p ../../contrib/tarballs