X-Git-Url: http://research.m1stereo.tv/gitweb?a=blobdiff_plain;f=configure;h=2b3e755381a60b2726dcf11edaee3876f6d03ac6;hb=c4612a42677dd9c1c781ead06461f2be6178cae8;hp=e1985812fc363b90a3c622d7a1f3da0e1eb4b300;hpb=4dbf3ebb9b3642a02300bd2388c6b2211160cb5a;p=melted diff --git a/configure b/configure index e198581..2b3e755 100755 --- a/configure +++ b/configure @@ -1,6 +1,9 @@ -#!/bin/sh +#!/bin/bash -function show_help +export version=0.3.1 +export soversion=1 + +show_help() { cat << EOF Non-autotool config script for MLT. @@ -12,6 +15,7 @@ Help options: General build options: --prefix=directory - install prefix for path (default: $prefix) + --libdir=directory - lib directory (default: $prefix/lib) --enable-gpl - Enable GPL components --disable-debug - Compile without debug support (default: on) --disable-mmx - Compile without MMX support (default: on) @@ -32,12 +36,15 @@ EOF echo } -function build_config +build_config() { ( echo "version=$version" + echo "soversion=$soversion" echo "prefix=$prefix" + echo "libdir=$libdir" echo "bindir=$prefix/bin" + echo "targetos=$targetos" [ "$mmx" = "true" ] && echo "MMX_FLAGS=-DUSE_MMX" @@ -50,18 +57,34 @@ function build_config [ "$cpu" != "" ] && echo "TARGETARCH=-march=$cpu" && echo "TARGETCPU=-mcpu=$cpu" - - [ "`uname`" = "Linux" ] && + echo "OPTIMISATIONS=-O4 -pipe -fomit-frame-pointer" + + echo "CFLAGS+=-Wall -fPIC -DPIC \$(TARGETARCH) \$(TARGETCPU) \$(OPTIMISATIONS) \$(MMX_FLAGS) \$(DEBUG_FLAGS) \$(LARGE_FILE)" + + case $targetos in + Darwin) + echo "CFLAGS+=-D__DARWIN__ `sdl-config --cflags`" + echo "SHFLAGS=-dynamiclib" + echo "LDFLAGS+=`sdl-config --libs`" + ;; + Linux) + echo "OPTIMISATIONS+=-ffast-math" + echo "CFLAGS+=-pthread" + echo "SHFLAGS=-shared" echo "LIBDL=-ldl" - - echo "OPTIMISATIONS=-O4 -pipe -ffast-math -fomit-frame-pointer" - echo "CFLAGS+=-Wall -fPIC -DPIC \$(TARGETARCH) \$(TARGETCPU) \$(OPTIMISATIONS) \$(MMX_FLAGS) \$(DEBUG_FLAGS) \$(LARGE_FILE) -pthread" + echo "RDYNAMIC=-rdynamic" + ;; + *) + ;; + esac + echo "LIBSUF=$LIBSUF" ) > config.mak echo "#!/bin/sh" > mlt-config ( echo export version=$version echo export prefix=$prefix + echo export libdir=$libdir echo export bindir=$prefix/bin ) >> mlt-config @@ -70,17 +93,19 @@ function build_config echo -n > packages.dat } -function build_pkgconfig +build_pkgconfig() { for i in framework valerie miracle do - echo "prefix=$prefix" >mlt-$i.pc - echo "exec_prefix=$prefix" >>mlt-$i.pc - echo "libdir=$prefix/lib" >>mlt-$i.pc - echo "includedir=$prefix/include" >>mlt-$i.pc - echo "version=$version" >>mlt-$i.pc - echo "cflags=`grep ^$i packages.dat | cut -f 2`" >>mlt-$i.pc - echo "libs=`grep ^$i packages.dat | cut -f 3`" >>mlt-$i.pc + echo prefix="$prefix" > mlt-$i.pc + ( + echo exec_prefix=$prefix + echo libdir=$libdir + echo includedir=$prefix/include + echo version=$version + echo cflags=`grep ^$i packages.dat | cut -f 2` + echo libs=`grep ^$i packages.dat | cut -f 3` + ) >> mlt-$i.pc cat mlt-$i.pc.in >>mlt-$i.pc done } @@ -91,19 +116,37 @@ set +x # Define build directory for scripts called export build_dir=`dirname $0` export prefix=/usr/local +export libdir="" export help=0 -export version=0.1.1 export debug=true export mmx=true export gpl=false export cpu= +# Determine OS +targetos=$(uname -s) +# Chose appropriate suffix for libraries +case $targetos in + Darwin) + LIBSUF=".dylib" + mmx=false + ;; + Linux) + LIBSUF=".so" + ;; + *) + LIBSUF=".so" + ;; +esac +export LIBSUF + # Iterate through arguments for i in "$@" do case $i in --help ) help=1 ;; --prefix=* ) prefix="${i#--prefix=}" ;; + --libdir=* ) libdir="${i#--libdir=}" ;; --disable-debug ) debug=false ;; --disable-mmx ) mmx=false ;; --enable-gpl ) gpl=true ;; @@ -111,8 +154,26 @@ do esac done +# Determine the libdir if it's not specified in the args +[ "$libdir" = "" ] && libdir=$prefix/lib + +# Double check mmx (may end up disabling mmx on non-linux platforms incorrectly) +if [ "$mmx" = "true" ] +then + grep mmx /proc/cpuinfo > /dev/null 2>&1 || mmx=false +fi + # Show help if requested -[ $help = 1 ] && show_help || build_config +if [ $help = 1 ] +then + show_help +else + # Log the configuration history + date >> config.log + echo "$0 $@" >> config.log + + build_config +fi # Iterate through each of the components for i in framework modules inigo valerie miracle humperdink @@ -136,4 +197,3 @@ build_pkgconfig ( [ "$gpl" = "false" ] && echo "GPL Components are disabled" || echo "GPL License Used" ) -