]> git.sesse.net Git - vlc/blobdiff - extras/package/ios/build.sh
iOS: more building fixes
[vlc] / extras / package / ios / build.sh
index e6aa6995de0ab9b44c26e2ea617a446b2b157496..2f78ef7c44a23f58a4f7dfb57447db7309aec6a7 100755 (executable)
@@ -3,8 +3,9 @@ set -e
 
 PLATFORM=OS
 VERBOSE=no
-SDK_VERSION=5.1
-SDK_MIN=5.0
+SDK_VERSION=6.1
+SDK_MIN=5.1
+ARCH=armv7
 
 usage()
 {
@@ -12,8 +13,9 @@ cat << EOF
 usage: $0 [-s] [-k sdk]
 
 OPTIONS
-   -k       Specify which sdk to use ('xcodebuild -showsdks', current: ${SDK})
-   -s       Build for simulator
+   -k <sdk>      Specify which sdk to use ('xcodebuild -showsdks', current: ${SDK})
+   -s            Build for simulator
+   -a <arch>     Specify which arch to use (current: ${ARCH})
 EOF
 }
 
@@ -34,7 +36,7 @@ info()
     echo "[${blue}info${normal}] $1"
 }
 
-while getopts "hvsk:" OPTION
+while getopts "hvsk:a:" OPTION
 do
      case $OPTION in
          h)
@@ -51,6 +53,9 @@ do
          k)
              SDK=$OPTARG
              ;;
+         a)
+             ARCH=$OPTARG
+             ;;
          ?)
              usage
              exit 1
@@ -69,15 +74,15 @@ if [ "$VERBOSE" = "yes" ]; then
    out="/dev/stdout"
 fi
 
-info "Building libvlc for the iOS"
+info "Building libvlc for iOS"
 
 if [ "$PLATFORM" = "Simulator" ]; then
     TARGET="i686-apple-darwin11"
     ARCH="i386"
+    OPTIM="-O3 -g"
 else
     TARGET="arm-apple-darwin11"
-    ARCH="armv7"
-    OPTIM="-mno-thumb"
+    OPTIM="-O3 -g"
 fi
 
 info "Using ${ARCH} with SDK version ${SDK_VERSION}"
@@ -100,9 +105,9 @@ then
     exit 1
 fi
 
-BUILDDIR="${VLCROOT}/build-ios-${PLATFORM}"
+BUILDDIR="${VLCROOT}/build-ios-${PLATFORM}/${ARCH}"
 
-PREFIX="${VLCROOT}/install-ios-${PLATFORM}"
+PREFIX="${VLCROOT}/install-ios-${PLATFORM}/${ARCH}"
 
 IOS_GAS_PREPROCESSOR="${VLCROOT}/extras/tools/gas/gas-preprocessor.pl"
 
@@ -117,7 +122,7 @@ spushd "${VLCROOT}/extras/tools"
 make && make .gas
 spopd
 
-info "Building contrib for iOS in '${VLCROOT}/contrib/iPhone${PLATFORM}'"
+info "Building contrib for iOS in '${VLCROOT}/contrib/iPhone${PLATFORM}-${ARCH}'"
 
 # The contrib will read the following
 export AR="xcrun ar"
@@ -151,9 +156,17 @@ if [ "$PLATFORM" = "Simulator" ]; then
 fi
 
 if [ "$PLATFORM" = "OS" ]; then
-  export LDFLAGS="-L${SDKROOT}/usr/lib -arch ${ARCH}  -isysroot ${SDKROOT}  -miphoneos-version-min=${SDK_MIN} "
+  export LDFLAGS="-L${SDKROOT}/usr/lib -arch ${ARCH} -isysroot ${SDKROOT} -miphoneos-version-min=${SDK_MIN}"
+else
+  export LDFLAGS="-syslibroot=${SDKROOT}/ -arch ${ARCH} -miphoneos-version-min=${SDK_MIN}"
+fi
+
+if [ "$PLATFORM" = "OS" ]; then
+    EXTRA_CFLAGS="-arch ${ARCH} -mcpu=cortex-a8"
+    EXTRA_LDFLAGS="-arch ${ARCH}"
 else
-  export LDFLAGS="-syslibroot=${SDKROOT}/ -arch ${ARCH} "
+    EXTRA_CFLAGS="-m32"
+    EXTRA_LDFLAGS="-m32"
 fi
 
 info "LD FLAGS SELECTED = '${LDFLAGS}'"
@@ -161,25 +174,27 @@ info "LD FLAGS SELECTED = '${LDFLAGS}'"
 spushd ${VLCROOT}/contrib
 
 echo ${VLCROOT}
-mkdir -p "${VLCROOT}/contrib/iPhone${PLATFORM}"
-cd "${VLCROOT}/contrib/iPhone${PLATFORM}"
+mkdir -p "${VLCROOT}/contrib/iPhone${PLATFORM}-${ARCH}"
+cd "${VLCROOT}/contrib/iPhone${PLATFORM}-${ARCH}"
 
 if [ "$PLATFORM" = "OS" ]; then
-  export AS="${IOS_GAS_PREPROCESSOR} ${CC}"
-  export ASCPP="${IOS_GAS_PREPROCESSOR} ${CC}"
-  export CCAS="${IOS_GAS_PREPROCESSOR} ${CC}"
+      export AS="${IOS_GAS_PREPROCESSOR} ${CC}"
+      export ASCPP="${IOS_GAS_PREPROCESSOR} ${CC}"
+      export CCAS="${IOS_GAS_PREPROCESSOR} ${CC}"
 else
   export AS="xcrun as"
   export ASCPP="xcrun as"
 fi
 
-../bootstrap --host=${TARGET} --build="i686-apple-darwin10" --disable-disc --disable-sout \
+../bootstrap --host=${TARGET} --build="i686-apple-darwin10" --prefix=${VLCROOT}/contrib/${TARGET}-${ARCH} --disable-gpl \
+    --disable-disc --disable-sout \
     --enable-small \
     --disable-sdl \
     --disable-SDL_image \
     --disable-fontconfig \
     --disable-ass \
     --disable-freetype2 \
+    --disable-iconv \
     --disable-fribidi \
     --disable-zvbi \
     --disable-kate \
@@ -198,7 +213,12 @@ fi
     --disable-orc \
     --disable-schroedinger \
     --disable-libmpeg2 \
-    --disable-mad > ${out}
+    --disable-chromaprint \
+    --disable-mad \
+    --disable-taglib > ${out}
+
+echo "EXTRA_CFLAGS += ${EXTRA_CFLAGS}" >> config.mak
+echo "EXTRA_LDFLAGS += ${EXTRA_LDFLAGS}" >> config.mak
 make
 spopd
 
@@ -219,14 +239,6 @@ if [ ".$PLATFORM" != ".Simulator" ]; then
     export AVFORMAT_LIBS="-L${PREFIX}/lib -lavcodec -lz -lavutil -lavformat"
 fi
 
-export DVBPSI_CFLAGS="-I${VLCROOT}/contrib-ios-${TARGET}/include "
-export DVBPSI_LIBS="-L${VLCROOT}/contrib-ios-${TARGET}/lib "
-
-export SWSCALE_CFLAGS="-I${VLCROOT}/contrib-ios-${TARGET}/include "
-export SWSCALE_LIBS="-L${VLCROOT}/contrib-ios-${TARGET}/lib "
-
-
-
 mkdir -p ${BUILDDIR}
 spushd ${BUILDDIR}
 
@@ -235,11 +247,11 @@ info ">> --prefix=${PREFIX} --host=${TARGET}"
 # Run configure only upon changes.
 if [ "${VLCROOT}/configure" -nt config.log -o \
      "${THIS_SCRIPT_PATH}" -nt config.log ]; then
-CONTRIB_DIR=${VLCROOT}/contrib-ios-${TARGET} \
 ${VLCROOT}/configure \
     --prefix="${PREFIX}" \
     --host="${TARGET}" \
-    --enable-debug \
+    --with-contrib="${VLCROOT}/contrib/${TARGET}-${ARCH}" \
+    --disable-debug \
     --enable-static \
     --disable-macosx \
     --disable-macosx-vout \
@@ -247,23 +259,23 @@ ${VLCROOT}/configure \
     --disable-macosx-qtkit \
     --disable-macosx-eyetv \
     --disable-macosx-vlc-app \
+    --disable-macosx-avfoundation \
     --enable-audioqueue \
+    --enable-ios-audio \
     --enable-ios-vout \
+    --enable-ios-vout2 \
     --disable-shared \
     --disable-macosx-quartztext \
     --enable-avcodec \
-    --disable-mkv \
-    --enable-dvbpsi \
-    --enable-swscale \
-    --disable-projectm \
+    --enable-mkv \
+    --enable-opus \
     --disable-sout \
     --disable-faad \
     --disable-lua \
-    --disable-mad \
     --disable-a52 \
     --disable-fribidi \
     --disable-macosx-audio \
-    --disable-qt4 --disable-skins2 \
+    --disable-qt --disable-skins2 \
     --disable-libgcrypt \
     --disable-vcd \
     --disable-vlc \
@@ -271,10 +283,8 @@ ${VLCROOT}/configure \
     --disable-httpd \
     --disable-nls \
     --disable-glx \
-    --enable-visual \
-    --disable-lua \
     --disable-sse \
-    --disable-neon \
+    --enable-neon \
     --disable-notify \
     --enable-live555 \
     --enable-realrtsp \
@@ -282,7 +292,6 @@ ${VLCROOT}/configure \
     --enable-swscale \
     --disable-projectm \
     --disable-libass \
-    --disable-sqlite \
     --disable-libxml2 \
     --disable-goom \
     --disable-dvdread \
@@ -296,16 +305,16 @@ ${VLCROOT}/configure \
     --disable-fluidsynth \
     --disable-jack \
     --disable-pulse \
-    --disable-sout \
-    --disable-faad \
-    --disable-lua \
-    --disable-mad \
     --disable-mtp \
-    --disable-ogg \
-    --disable-speex \
-    --disable-theora \
-    --disable-flac \
-    --disable-mmx > ${out} # MMX and SSE support requires llvm which is broken on Simulator
+    --enable-ogg \
+    --enable-speex \
+    --enable-theora \
+    --enable-flac \
+    --disable-screen \
+    --disable-freetype \
+    --disable-taglib \
+    --disable-mmx \
+    --disable-mad > ${out} # MMX and SSE support requires llvm which is broken on Simulator
 fi
 
 CORE_COUNT=`sysctl -n machdep.cpu.core_count`
@@ -316,4 +325,82 @@ make -j$MAKE_JOBS > ${out}
 
 info "Installing libvlc"
 make install > ${out}
+
+find ${PREFIX}/lib/vlc/plugins -name *.a -type f -exec cp '{}' ${PREFIX}/lib/vlc/plugins \;
+cp -R "${VLCROOT}/contrib/${TARGET}-${ARCH}" "${PREFIX}/contribs"
+
+info "Removing unneeded modules"
+blacklist="
+stats
+access_bd
+shm
+access_imem
+oldrc
+real
+hotkeys
+gestures
+sap
+dynamicoverlay
+rss
+ball
+marq
+magnify
+audiobargraph_
+clone
+mosaic
+osdmenu
+puzzle
+mediadirs
+t140
+ripple
+motion
+sharpen
+grain
+posterize
+mirror
+wall
+scene
+blendbench
+psychedelic
+alphamask
+netsync
+audioscrobbler
+motiondetect
+motionblur
+export
+smf
+podcast
+bluescreen
+erase
+stream_filter_record
+speex_resampler
+remoteosd
+magnify
+gradient
+tospdif
+dtstofloat32
+logger
+visual
+fb
+aout_file
+dummy
+invert
+sepia
+wave
+hqdn3d
+headphone_channel_mixer
+gaussianblur
+gradfun
+extract
+colorthres
+antiflicker
+anaglyph
+remap
+"
+
+for i in ${blacklist}
+do
+    find ${PREFIX}/lib/vlc/plugins -name *$i* -type f -exec rm '{}' \;
+done
+
 popd