X-Git-Url: https://git.sesse.net/?a=blobdiff_plain;f=configure;h=c980af3fad4b9fae4faefacb42962d2a9672a52e;hb=bc5432678809b945cbb36bec73d75c1f162e932c;hp=68e490edcf82261a320969efb90de8d9e1fc52bb;hpb=ef7ca733ee283439a791bfcaea8016bfa3f44a29;p=mlt diff --git a/configure b/configure index 68e490ed..c980af3f 100755 --- a/configure +++ b/configure @@ -1,6 +1,9 @@ #!/bin/sh -function show_help +export version=0.7.5 +export soversion=4 + +show_help() { cat << EOF Non-autotool config script for MLT. @@ -12,13 +15,19 @@ Help options: General build options: --prefix=directory - install prefix for path (default: $prefix) + --libdir=directory - lib directory (default: $prefix/lib) + --datadir=directory - data directory (default: $prefix/share) + --mandir=directory - man documentation directory (default: $prefix/share/man) --enable-gpl - Enable GPL components - --enable-motion-est - Enable motion estimation components + --enable-debug - Compile without optimizations support (default: off) --disable-debug - Compile without debug support (default: on) --disable-mmx - Compile without MMX support (default: on) - --cpu='cpu' - Compile for a specific CPU/architectre (default: none) + --disable-sse - Compile without SSE support (default: on) + --disable-sse2 - Compile without SSE2 support (default: on) + --arch='arch' - Compile for a specific architecture (default: none) + --cpu='cpu' - Compile for a specific CPU (default: none) -Module disables options: +Module disable options: EOF @@ -33,41 +42,89 @@ EOF echo } -function build_config +build_config() { ( echo "version=$version" + echo "soversion=$soversion" echo "prefix=$prefix" + echo "libdir=$libdir" echo "bindir=$prefix/bin" + echo "datadir=$datadir" + echo "mandir=$mandir" echo "targetos=$targetos" [ "$mmx" = "true" ] && echo "MMX_FLAGS=-DUSE_MMX" + [ "$sse" = "true" ] && + echo "SSE_FLAGS=-DUSE_SSE" + + [ "$sse2" = "true" ] && + echo "SSE2_FLAGS=-DUSE_SSE2" + [ "$debug" = "true" ] && echo "DEBUG_FLAGS=-g" echo "LARGE_FILE=-D_FILE_OFFSET_BITS=64 -D_LARGEFILE_SOURCE" - [ "$cpu" != "" ] && - echo "TARGETARCH=-march=$cpu" && - echo "TARGETCPU=-mcpu=$cpu" + [ "$arch" != "" ] && echo "TARGETARCH=-march=$arch" + [ "$cpu" != "" ] && echo "TARGETCPU=-mcpu=$cpu" + if [ "$optimisations" = "true" ] + then + echo "OPTIMISATIONS=-O2 -pipe" + # Since gcc 4.6, this optimization enabled with -O1 causes filter_line_sse2 to crash. + echo "OPTIMISATIONS+=-fno-tree-dominator-opts" + # Since gcc 4.6, this optimization enabled with -O2 causes filter_line_sse2 to crash. + echo "OPTIMISATIONS+=-fno-tree-pre" + fi - echo "OPTIMISATIONS=-O4 -pipe -ffast-math -fomit-frame-pointer" - echo "CFLAGS+=-Wall -fPIC -DPIC \$(TARGETARCH) \$(TARGETCPU) \$(OPTIMISATIONS) \$(MMX_FLAGS) \$(DEBUG_FLAGS) \$(LARGE_FILE)" + echo "CFLAGS+=-Wall -DPIC \$(TARGETARCH) \$(TARGETCPU) \$(OPTIMISATIONS) \$(MMX_FLAGS) \$(SSE_FLAGS) \$(SSE2_FLAGS) \$(DEBUG_FLAGS) \$(LARGE_FILE)" case $targetos in Darwin) - echo "CFLAGS+=-D__DARWIN__ `sdl-config --cflags`" + sysctl -a hw | grep "x86_64: 1" > /dev/null && echo "ARCH_X86_64=1" && echo "CFLAGS+=-DARCH_X86_64" + echo "CFLAGS+=-fPIC -D__DARWIN__ `sdl-config --cflags`" echo "SHFLAGS=-dynamiclib" echo "LDFLAGS+=`sdl-config --libs`" ;; - Linux) - echo "CFLAGS+=-pthread" + Linux|GNU/kFreeBSD) + [ "$(uname -m)" = "x86_64" ] && echo "ARCH_X86_64=1" && echo "CFLAGS+=-DARCH_X86_64" + [ "$optimisations" = "true" ] && + echo "OPTIMISATIONS+=-ffast-math" + echo "CFLAGS+=-fPIC -pthread" echo "SHFLAGS=-shared" echo "LIBDL=-ldl" echo "RDYNAMIC=-rdynamic" + echo "LDFLAGS+=-Wl,--no-undefined -Wl,--as-needed" + ;; + FreeBSD) + [ "$(uname -m)" = "amd64" -o "$(uname -m)" = "x86_64" ] && echo "ARCH_X86_64=1" && echo "CFLAGS+=-DARCH_X86_64" + [ "$optimisations" = "true" ] && + echo "OPTIMISATIONS+=-ffast-math" + echo "CFLAGS+=-fPIC -pthread" + echo "SHFLAGS=-shared" + echo "RDYNAMIC=-rdynamic" + echo "LDFLAGS+=-Wl,--no-undefined -Wl,--as-needed" ;; + NetBSD) + [ "$(uname -m)" = "amd64" ] && echo "ARCH_X86_64=1" && echo "CFLAGS+=-DARCH_X86_64" + [ "$optimisations" = "true" ] && + echo "OPTIMISATIONS+=-ffast-math" + echo "CFLAGS+=-pthread" + echo "SHFLAGS=-shared" + echo "RDYNAMIC=-rdynamic" + echo "LDFLAGS+=-Wl,--no-undefined -Wl,--as-needed" + ;; + MinGW) + [ "$(uname -m)" = "x86_64" ] && echo "ARCH_X86_64=1" && echo "CFLAGS+=-DARCH_X86_64" + [ "$optimisations" = "true" ] && + echo "OPTIMISATIONS+=-ffast-math" + echo "SHFLAGS=-shared" + echo "LIBDL=-ldl" + echo "RDYNAMIC=" + echo "LDFLAGS+=-Wl,--no-undefined -Wl,--as-needed" + ;; *) ;; esac @@ -78,6 +135,7 @@ function build_config ( echo export version=$version echo export prefix=$prefix + echo export libdir=$libdir echo export bindir=$prefix/bin ) >> mlt-config @@ -86,19 +144,33 @@ 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 - cat mlt-$i.pc.in >>mlt-$i.pc - done + echo prefix="$prefix" > mlt-framework.pc + ( + echo exec_prefix=$prefix + echo libdir=$libdir + echo includedir=$prefix/include + echo datadir=$datadir + echo mandir=$mandir + echo version=$version + echo cflags=`grep ^framework packages.dat | cut -f 2` + echo libs=`grep ^framework packages.dat | cut -f 3` + ) >> mlt-framework.pc + cat mlt-framework.pc.in >>mlt-framework.pc + + echo prefix="$prefix" > mlt++.pc + ( + echo exec_prefix=$prefix + echo libdir=$libdir + echo includedir=$prefix/include + echo datadir=$datadir + echo mandir=$mandir + echo version=$version + echo cflags=`grep ^mlt++ packages.dat | cut -f 2` + echo libs=`grep ^mlt++ packages.dat | cut -f 3` + ) >> mlt++.pc + cat mlt++.pc.in >>mlt++.pc } # Debug mode @@ -107,13 +179,19 @@ set +x # Define build directory for scripts called export build_dir=`dirname $0` export prefix=/usr/local +export libdir="" +export datadir="" +export mandir="" export help=0 -export version=0.1.1 +export optimisations=true export debug=true export mmx=true +export sse=true +export sse2=true export gpl=false +export arch= export cpu= -export motionest=false +export targetos= # Determine OS targetos=$(uname -s) @@ -121,11 +199,14 @@ targetos=$(uname -s) case $targetos in Darwin) LIBSUF=".dylib" - mmx=false ;; - Linux) + Linux|FreeBSD|NetBSD) LIBSUF=".so" ;; + MINGW32_NT-*) + targetos="MinGW" + LIBSUF=".dll" + ;; *) LIBSUF=".so" ;; @@ -138,25 +219,96 @@ do case $i in --help ) help=1 ;; --prefix=* ) prefix="${i#--prefix=}" ;; + --libdir=* ) libdir="${i#--libdir=}" ;; + --datadir=* ) datadir="${i#--datadir=}" ;; + --mandir=* ) mandir="${i#--mandir=}" ;; + --enable-debug ) optimisations=false ;; --disable-debug ) debug=false ;; - --disable-mmx ) mmx=false ;; + --disable-mmx ) mmx=false; sse=false; sse2=false ;; + --disable-sse ) sse=false; sse2=false ;; + --disable-sse2 ) sse2=false ;; --enable-gpl ) gpl=true ;; - --enable-motion-est ) motionest=true ;; + --arch=* ) arch="${i#--arch=}" ;; --cpu=* ) cpu="${i#--cpu=}" ;; esac done -# Double check mmx (may end up disabling mmx on non-linux platforms incorrectly) +# Determine the libdir if it's not specified in the args +[ "$libdir" = "" ] && libdir=$prefix/lib +[ "$datadir" = "" ] && datadir=$prefix/share +[ "$mandir" = "" ] && mandir=$prefix/share/man + +# Double check MMX (Darwin, Linux and FreeBSD supported, may end up disabling MMX on other platforms incorrectly) if [ "$mmx" = "true" ] then - grep mmx /proc/cpuinfo > /dev/null 2>&1 || mmx=false + case $targetos in + Darwin) + sysctl -a hw | grep "mmx: 1" > /dev/null || mmx=false + ;; + Linux) + grep mmx /proc/cpuinfo > /dev/null 2>&1 || mmx=false + ;; + FreeBSD) + [ "$(make -V MACHINE_CPU:Mmmx)" ] || mmx=false + ;; + *) + grep mmx /proc/cpuinfo > /dev/null 2>&1 || mmx=false + ;; + esac +fi + +# Double check SSE (Darwin, Linux and FreeBSD supported, may end up disabling SSE on other platforms incorrectly) +if [ "$sse" = "true" ] +then + case $targetos in + Darwin) + sysctl -a hw | grep "sse: 1" > /dev/null || sse=false + ;; + Linux) + grep sse /proc/cpuinfo > /dev/null 2>&1 || sse=false + ;; + FreeBSD) + [ "$(make -V MACHINE_CPU:Msse)" ] || sse=false + ;; + *) + grep sse /proc/cpuinfo > /dev/null 2>&1 || sse=false + ;; + esac +fi + +# Double check SSE2 (Darwin, Linux and FreeBSD supported, may end up disabling SSE2 on other platforms incorrectly) +if [ "$sse2" = "true" ] +then + case $targetos in + Darwin) + sysctl -a hw | grep "sse2: 1" > /dev/null || sse2=false + ;; + Linux) + grep sse2 /proc/cpuinfo > /dev/null 2>&1 || sse2=false + ;; + FreeBSD) + [ "$(make -V MACHINE_CPU:Msse2)" ] || sse2=false + ;; + *) + grep sse2 /proc/cpuinfo > /dev/null 2>&1 || sse2=false + ;; + esac 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 +for i in framework modules melt mlt++ swig do if [ -x src/$i/configure ] then @@ -177,8 +329,3 @@ build_pkgconfig ( [ "$gpl" = "false" ] && echo "GPL Components are disabled" || echo "GPL License Used" ) - -if [ "$motionest" = "true" -a "$gpl" = "false" ] -then - echo "Add the --enable-gpl flag to build the motion estimation components." -fi