X-Git-Url: https://git.sesse.net/?a=blobdiff_plain;f=contrib%2Fbootstrap;h=ced4fe081abf184588999266723edbeaa591c5db;hb=da197ddb1bf34128ccb542dc38d91e47ce3b9244;hp=024ead91a22dcbca2dc67a66be84544e9c0b59ac;hpb=44b51330e420b7af111833adf7f2d77eb45278e6;p=vlc diff --git a/contrib/bootstrap b/contrib/bootstrap index 024ead91a2..ced4fe081a 100755 --- a/contrib/bootstrap +++ b/contrib/bootstrap @@ -27,7 +27,11 @@ usage() 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-net configure to not build networking packages" echo " --disable-sout configure to not build stream output packages" + echo " --enable-small optimize libraries for size with slight speed decrease [DANGEROUS]" + echo " --disable-gpl configure to not build viral GPL code" + echo " --disable-optim disable optimization in libraries" } BUILD= @@ -36,9 +40,12 @@ PREFIX= PKGS_ENABLE= PKGS_DISABLE= BUILD_ENCODERS="1" +BUILD_NETWORK="1" BUILD_DISCS="1" +GPL="1" +WITH_OPTIMIZATION="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 @@ -63,9 +70,21 @@ do --disable-disc) BUILD_DISCS= ;; + --disable-net) + BUILD_NETWORK= + ;; --disable-sout) BUILD_ENCODERS= ;; + --disable-optim) + WITH_OPTIMIZATION= + ;; + --enable-small) + ENABLE_SMALL=1 + ;; + --disable-gpl) + GPL= + ;; --disable-*) PKGS_DISABLE="${PKGS_DISABLE} ${1#--disable-}" ;; @@ -84,7 +103,7 @@ done if test -z "$BUILD" then echo -n "Guessing build system... " - BUILD="`cc -dumpmachine`" + BUILD="`${CC:-cc} -dumpmachine`" if test -z "$BUILD"; then echo "FAIL!" exit 1 @@ -103,25 +122,18 @@ 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 +exec 3>config.mak || exit $? cat >&3 << EOF # This file was automatically generated. # 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 @@ -144,8 +156,82 @@ add_make_enabled() done } +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 "IOS_SDK=${SDKROOT}" +} + +check_macosx_sdk() +{ + if [ -z "${OSX_VERSION}" ] + then + OSX_VERSION=`xcrun --show-sdk-version` + echo "OSX_VERSION not specified, assuming $OSX_VERSION" + fi + 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 + SDKROOT_NOT_FOUND="$SDKROOT" + SDKROOT=`xcrun --show-sdk-path` + 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_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}" + [ -z "${ANDROID_API}" ] && echo "You should set ANDROID_API environment variable (using default android-9)" && ANDROID_API := android-9 + add_make "ANDROID_API := ${ANDROID_API}" + [ ${ANDROID_ABI} = "armeabi-v7a" ] && add_make_enabled "HAVE_NEON" + [ ${ANDROID_ABI} = "armeabi-v7a" ] && add_make_enabled "HAVE_ARMV7A" + [ ${ANDROID_ABI} = "arm64-v8a" ] && add_make_enabled "HAVE_NEON" + [ ${ANDROID_ABI} = "arm64-v8a" ] && add_make_enabled "HAVE_ARMV8A" + [ ${ANDROID_ABI} = "armeabi" -a -z "${NO_ARMV6}" ] && add_make_enabled "HAVE_ARMV6" +} + +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 "$BUILD_NETWORK" || add_make_enabled "BUILD_NETWORK" +test -z "$ENABLE_SMALL" || add_make_enabled "ENABLE_SMALL" +test -z "$GPL" || add_make_enabled "GPL" +test -z "$WITH_OPTIMIZATION" || add_make_enabled "WITH_OPTIMIZATION" # # Checks @@ -153,44 +239,76 @@ test -z "$BUILD_ENCODERS" || add_make_enabled "BUILD_ENCODERS" OS="${HOST#*-}" # strip architecture case "${OS}" in apple-darwin*) - add_make_enabled "HAVE_MACOSX" "HAVE_DARWIN_OS" "HAVE_BSD" - ;; - *darwin*) - add_make_enabled "HAVE_DARWIN_OS" "HAVE_BSD" + 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_FPU" + + case "${HOST}" in + *arm*) + add_make_enabled "HAVE_NEON" "HAVE_ARMV7A" + ;; + esac; + 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" + ;; + *arm64*|*aarch64*) + add_make "PLATFORM_SHORT_ARCH := arm64" + ;; + *i686*) + add_make "PLATFORM_SHORT_ARCH := x86" + ;; + *x86_64*) + add_make "PLATFORM_SHORT_ARCH := x86_64" + ;; + *mipsel*) + add_make "PLATFORM_SHORT_ARCH := mips" + ;; + esac + ;; *linux*) add_make_enabled "HAVE_LINUX" ;; - *wince*) - add_make_enabled "HAVE_WINCE" - ;; *mingw*) add_make_enabled "HAVE_WIN32" ;; + *solaris*) + add_make_enabled "HAVE_SOLARIS" + ;; esac # # Results output # test -e Makefile && unlink Makefile -ln -sf ../src/main.mak Makefile +ln -sf ../../contrib/src/main.mak Makefile || exit $? 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 mostlyclean clean everything except source tarballs * make clean clean everything - * make list list packages + * make package prepare prebuilt packages EOF + +mkdir -p ../../contrib/tarballs || exit $?