From 7e2edad8efea55e8df1faa695d1389ef4e326d7c Mon Sep 17 00:00:00 2001 From: Stefano Pigozzi Date: Tue, 16 Jul 2013 13:28:28 +0200 Subject: switch the build system to waf This commit adds a new build system based on waf. configure and Makefile are deprecated effective immediately and someday in the future they will be removed (they are still available by running ./old-configure). You can find how the choice for waf came to be in `DOCS/waf-buildsystem.rst`. TL;DR: we couldn't get the same level of abstraction and customization with other build systems we tried (CMake and autotools). For guidance on how to build the software now, take a look at README.md and the cross compilation guide. CREDITS: This is a squash of ~250 commits. Some of them are not by me, so here is the deserved attribution: - @wm4 contributed some Windows fixes, renamed configure to old-configure and contributed to the bootstrap script. Also, GNU/Linux testing. - @lachs0r contributed some Windows fixes and the bootstrap script. - @Nikoli contributed a lot of testing and discovered many bugs. - @CrimsonVoid contributed changes to the bootstrap script. --- old-configure | 3573 +++++++++++++++++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 3573 insertions(+) create mode 100755 old-configure (limited to 'old-configure') diff --git a/old-configure b/old-configure new file mode 100755 index 0000000000..fe77403c6b --- /dev/null +++ b/old-configure @@ -0,0 +1,3573 @@ +#! /bin/sh +# +# Original version (C) 2000 Pontscho/fresh!mindworkz +# pontscho@makacs.poliod.hu +# +# History / Contributors: Check the Subversion log. +# +# Cleanups all over the place (c) 2001 pl +# +# +# This configure script is *not* autoconf-based and has different semantics. +# It attempts to autodetect all settings and options where possible. It is +# possible to override autodetection with the --enable-option/--disable-option +# command line parameters. --enable-option forces the option on skipping +# autodetection. Yes, this means that compilation may fail and yes, this is not +# how autoconf-based configure scripts behave. +# +# configure generates a series of configuration files: +# - config.h contains #defines that are used in the C code. +# - config.mak is included from the Makefiles. +# +# If you want to add a new check for $feature, look at the existing checks +# and try to use helper functions where you can. +# +# Furthermore you need to add the variable _feature to the list of default +# settings and set it to one of yes/no/auto. Also add appropriate +# --enable-feature/--disable-feature command line options. +# The results of the check should be written to config.h and config.mak +# at the end of this script. The variable names used for this should be +# uniform, i.e. if the option is named 'feature': +# +# _feature : should have a value of yes/no/auto +# def_feature : '#define ... 1' or '#undef ...' for conditional compilation +# _ld_feature : '-L/path/dir -lfeature' GCC options +# +############################################################################# + +# Prevent locale nonsense from breaking basic text processing utils +export LC_ALL=C + +# Store the configure line that was used +configuration="$*" + +# Prefer these macros to full length text ! +# These macros only return an error code - NO display is done +command_check() { + echo >> "$TMPLOG" + echo "$@" >> "$TMPLOG" + "$@" >> "$TMPLOG" 2>&1 + TMPRES="$?" + echo >> "$TMPLOG" + return "$TMPRES" +} + +compile_check() { + source="$1" + shift + echo >> "$TMPLOG" + cat "$source" >> "$TMPLOG" + echo >> "$TMPLOG" + echo "$_cc $WARNFLAGS $WARN_CFLAGS $CFLAGS $source $extra_cflags $_ld_static $extra_ldflags $libs_mplayer -o $TMPEXE $@" >> "$TMPLOG" + rm -f "$TMPEXE" + $_cc $WARNFLAGS $WARN_CFLAGS $CFLAGS "$source" $extra_cflags $_ld_static $extra_ldflags $libs_mplayer -o "$TMPEXE" "$@" >> "$TMPLOG" 2>&1 + TMPRES="$?" + echo >> "$TMPLOG" + echo >> "$TMPLOG" + return "$TMPRES" +} + +cc_check() { + compile_check $TMPC $@ +} + +cxx_check() { + compile_check $TMPCPP $@ -lstdc++ +} + +cflag_check() { + cat > $TMPC << EOF +int main(void) { return 0; } +EOF + compile_check $TMPC $@ +} + +header_check() { + cat > $TMPC << EOF +#include <$1> +int main(void) { return 0; } +EOF + shift + compile_check $TMPC $@ +} + +return_check() { + cat > $TMPC << EOF +#include <$1> +int main(void) { return $2; } +EOF + shift 2 + compile_check $TMPC $@ +} + +statement_check() { + cat > $TMPC << EOF +#include <$1> +int main(void) { $2; return 0; } +EOF + shift + shift + compile_check $TMPC $@ +} + +define_statement_check() { + cat > $TMPC << EOF +#define $1 +#include <$2> +int main(void) { $3; return 0; } +EOF + shift 3 + compile_check $TMPC $@ +} + +return_statement_check() { + cat > $TMPC << EOF +#include <$1> +int main(void) { $2; return $3; } +EOF + shift 3 + compile_check $TMPC $@ +} + +inline_asm_check() { + cat > $TMPC << EOF +int main(void) { __asm__ volatile ($1); return 0; } +EOF + shift + compile_check $TMPC $@ +} + +# The following checks are special and should only be used with broken and +# non-selfsufficient headers that do not include all of their dependencies. + +header_check_broken() { + cat > $TMPC << EOF +#include <$1> +#include <$2> +int main(void) { return 0; } +EOF + shift + shift + compile_check $TMPC $@ +} + +statement_check_broken() { + cat > $TMPC << EOF +#include <$1> +#include <$2> +int main(void) { $3; return 0; } +EOF + shift 3 + compile_check $TMPC $@ +} + +pkg_config_add() { + unset IFS # shell should not be used for programming + echo >> "$TMPLOG" + echo "$_pkg_config --cflags $@" >> "$TMPLOG" + ctmp=$($_pkg_config --cflags "$@" 2>> "$TMPLOG") || return $? + echo >> "$TMPLOG" + echo "$_pkg_config --libs $@" >> "$TMPLOG" + ltmp=$($_pkg_config --libs "$@" 2>> "$TMPLOG") || return $? + echo >> "$TMPLOG" + echo "cflags: $ctmp" >> "$TMPLOG" + echo "libs: $ltmp" >> "$TMPLOG" + echo >> "$TMPLOG" + extra_cflags="$extra_cflags $ctmp" + libs_mplayer="$libs_mplayer $ltmp" +} + +tmp_run() { + "$TMPEXE" >> "$TMPLOG" 2>&1 +} + +# Display error message, flushes tempfile, exit +die () { + echo + echo "Error: $@" >&2 + echo >&2 + rm -f "$TMPEXE" "$TMPC" "$TMPS" "$TMPCPP" + echo "Check \"$TMPLOG\" if you do not understand why it failed." + exit 1 +} + +# OS test booleans functions +issystem() { + test "$(echo $system_name | tr A-Z a-z)" = "$(echo $1 | tr A-Z a-z)" +} +cygwin() { issystem "CYGWIN"; } +darwin() { issystem "Darwin"; } +dragonfly() { issystem "DragonFly"; } +freebsd() { issystem "FreeBSD" || issystem "GNU/kFreeBSD"; } +gnu() { issystem "GNU"; } +linux() { issystem "Linux"; } +mingw32() { issystem "MINGW32"; } +morphos() { issystem "MorphOS"; } +netbsd() { issystem "NetBSD"; } +openbsd() { issystem "OpenBSD"; } +win32() { cygwin || mingw32; } + +# arch test boolean functions +x86_32() { + case "$host_arch" in + i[3-9]86|k5|k6|k6-2|k6-3|pentium*|athlon*|i586-i686) return 0 ;; + *) return 1 ;; + esac +} + +x86_64() { + case "$host_arch" in + x86_64|amd64) return 0 ;; + *) return 1 ;; + esac +} + +x86() { + x86_32 || x86_64 +} + +ppc() { + case "$host_arch" in + ppc|ppc64|powerpc|powerpc64) return 0;; + *) return 1;; + esac +} + +alpha() { + case "$host_arch" in + alpha*) return 0;; + *) return 1;; + esac +} + +arm() { + case "$host_arch" in + arm*) return 0;; + *) return 1;; + esac +} + +# Use this before starting a check +echocheck() { + echo "============ Checking for $@ ============" >> "$TMPLOG" + echo ${_echo_n} "Checking for $@ ... ${_echo_c}" +} + +# Use this to echo the results of a check +echores() { + if test "$res_comment" ; then + res_comment="($res_comment)" + fi + echo "Result is: $@ $res_comment" >> "$TMPLOG" + echo "##########################################" >> "$TMPLOG" + echo "" >> "$TMPLOG" + echo "$@ $res_comment" + res_comment="" +} +############################################################################# + +# Check how echo works in this /bin/sh +case $(echo -n) in + -n) _echo_n= _echo_c='\c' ;; # SysV echo + *) _echo_n='-n ' _echo_c= ;; # BSD echo +esac + + +show_help(){ +cat << EOF +Usage: $0 [OPTIONS]... + +Configuration: + -h, --help display this help and exit + +Installation directories: + --prefix=DIR prefix directory for installation [/usr/local] + --bindir=DIR directory for installing binaries [PREFIX/bin] + --datadir=DIR directory for installing machine independent + data files (skins, etc) [PREFIX/share/mpv] + --mandir=DIR directory for installing man pages [PREFIX/share/man] + --docdir=DIR directory for installing docs [PREFIX/share/doc/mpv] + --confdir=DIR directory for installing configuration files + [PREFIX/etc/mpv] + +Optional features: + --disable-encoding disable encoding functionality [enable] + --disable-lua disable Lua scripting support [autodetect] + --lua=LUA select Lua package which should be autodetected + Choices: 51 51deb 52 52deb luajit + --disable-libguess disable libguess [autodetect] + --enable-terminfo use terminfo database for key codes [autodetect] + --enable-termcap use termcap database for key codes [autodetect] + --enable-termios use termios database for key codes [autodetect] + --disable-iconv disable iconv for encoding conversion [autodetect] + --enable-lirc enable LIRC (remote control) support [autodetect] + --enable-lircc enable LIRCCD (LIRC client daemon) input [autodetect] + --enable-joystick enable joystick support [disable] + --disable-vm disable X video mode extensions [autodetect] + --disable-xf86keysym disable support for multimedia keys [autodetect] + --enable-radio enable radio interface [disable] + --enable-radio-capture enable radio capture (through PCI/line-in) [disable] + --disable-radio-v4l2 disable Video4Linux2 radio interface [autodetect] + --disable-tv disable TV interface (TV/DVB grabbers) [enable] + --disable-tv-v4l2 disable Video4Linux2 TV interface [autodetect] + --disable-libv4l2 disable libv4l2 [autodetect] + --disable-pvr disable Video4Linux2 MPEG PVR [autodetect] + --enable-smb enable Samba (SMB) input [autodetect] + --disable-libquvi4 disable libquvi 0.4.x [autodetect] + --disable-libquvi9 disable libquvi 0.9.x [autodetect] + --enable-lcms2 enable LCMS2 support [autodetect] + --disable-vcd disable VCD support [autodetect] + --disable-bluray disable Blu-ray support [autodetect] + --disable-dvdread disable libdvdread [autodetect] + --disable-enca disable ENCA charset oracle library [autodetect] + --disable-pthreads disable Posix threads support [autodetect] + --disable-libass disable subtitle rendering with libass [autodetect] + --disable-libass-osd disable OSD rendering with libass [autodetect] + --enable-rpath enable runtime linker path for extra libs [disabled] + --disable-libpostproc disable postprocess filter (vf_pp) [autodetect] + --disable-libavdevice disable libavdevice demuxers [autodetect] + --disable-libavfilter disable libavfilter [autodetect] + --disable-vf-lavfi disable vf_lavfi libavfilter bridge [audodetect] + --disable-af-lavfi disable af_lavfi libavfilter bridge [audodetect] + +Codecs: + --enable-jpeg enable JPEG input/output support [autodetect] + --enable-libcdio enable libcdio support [autodetect] + --enable-libav skip Libav autodetection [autodetect] + --disable-ladspa disable LADSPA plugin support [autodetect] + --disable-libbs2b disable libbs2b audio filter support [autodetect] + --disable-mpg123 disable libmpg123 MP3 decoding support [autodetect] + +Resampler: + --disable-libavresample check for libswresample only [autodetect] + +Video output: + --enable-gl enable OpenGL video output [autodetect] + --enable-caca enable CACA video output [autodetect] + --enable-direct3d enable Direct3D video output [autodetect] + --enable-sdl enable SDL audio output [disable] + --enable-sdl2 enable SDL 2.0+ audio and video output [disable] + --enable-xv enable Xv video output [autodetect] + --enable-vdpau enable VDPAU acceleration [autodetect] + --enable-vda enable VDA acceleration [autodetect] + --enable-vaapi enable VAAPI acceleration [autodetect] + --enable-vm enable XF86VidMode support [autodetect] + --enable-xinerama enable Xinerama support [autodetect] + --enable-x11 enable X11 video output [autodetect] + --enable-wayland enable Wayland video output [autodetect] + --disable-xss disable screensaver support via xss [autodetect] + --disable-corevideo disable CoreVideo video output [autodetect] + --disable-cocoa disable Cocoa OpenGL backend [autodetect] + +Audio output: + --disable-alsa disable ALSA audio output [autodetect] + --disable-ossaudio disable OSS audio output [autodetect] + --disable-rsound disable RSound audio output [autodetect] + --disable-sndio disable sndio audio output [autodetect] + --disable-pulse disable Pulseaudio audio output [autodetect] + --disable-portaudio disable PortAudio audio output [autodetect] + --disable-jack disable JACK audio output [autodetect] + --enable-openal enable OpenAL audio output [disable] + --disable-coreaudio disable CoreAudio audio output [autodetect] + --disable-dsound disable DirectSound audio output [autodetect] + --disable-wasapi disable WASAPI (event mode) audio output [autodetect] + --disable-select disable using select() on the audio device [enable] + +Miscellaneous options: + --enable-cross-compile enable cross-compilation [disable] + --cc=COMPILER C compiler to build mpv [gcc] + --pkg-config=PKGCONFIG pkg-config to find some libraries [pkg-config] + --windres=WINDRES windres to build mpv [windres] + --target=PLATFORM target platform (i386-linux, arm-linux, etc) + --enable-static build a statically linked binary + --with-install=PATH path to a custom install program + --disable-manpage do not build and install manpage [auto] + --disable-pdf do not build and install PDF manual [auto] + --disable-build-date do not include binary compile time + +Advanced options: + --enable-shm enable shm [autodetect] + --disable-debug compile-in debugging information [enable] + --disable-optimization compile without -O2 [enable] + +Use these options if autodetection fails: + --extra-cflags=FLAGS extra CFLAGS + --extra-ldflags=FLAGS extra LDFLAGS + --extra-libs=FLAGS extra linker flags + --extra-libs-mpv=FLAGS extra linker flags for mpv + +This configure script is NOT autoconf-based, even though its output is similar. +It will try to autodetect all configuration options. If you --enable an option +it will be forcefully turned on, skipping autodetection. This can break +compilation, so you need to know what you are doing. +EOF +exit 0 +} #show_help() + +# GOTCHA: the variables below defines the default behavior for autodetection +# and have - unless stated otherwise - at least 2 states : yes no +# If autodetection is available then the third state is: auto +_install=install +_pkg_config=auto +_windres=auto +_cc=auto +test "$CC" && _cc="$CC" +_debug=-g +_opt=-O2 +_cross_compile=no +_prefix="/usr/local" +ffmpeg=auto +_encoding=yes +_disable_avresample=no +_x11=auto +_wayland=auto +_xss=auto +_xv=auto +_vdpau=auto +_vda=auto +_vda_refcounting=auto +_vaapi=auto +_direct3d=auto +_sdl=no +_sdl2=no +_dsound=auto +_wasapi=auto +_jpeg=auto +_gl=auto +_aa=auto +_caca=auto +_dvb=auto +_iconv=auto +_ossaudio=auto +_rsound=auto +_pulse=auto +_portaudio=auto +_jack=auto +_openal=no +_libcdio=auto +_mpg123=auto +_ladspa=auto +_libbs2b=auto +_vcd=auto +_bluray=auto +_dvdread=auto +_lcms2=auto +_xinerama=auto +_vm=auto +_xf86keysym=auto +_sndio=auto +_alsa=auto +_select=yes +_radio=no +_radio_capture=no +_radio_v4l2=auto +_tv=yes +_tv_v4l2=auto +_libv4l2=auto +_pvr=auto +_smb=auto +_libquvi4=auto +_libquvi9=auto +_libguess=auto +_joystick=no +_lirc=auto +_lircc=auto +_terminfo=auto +_termcap=auto +_termios=auto +_shm=auto +_cdda=auto +_coreaudio=auto +_corevideo=auto +_cocoa=auto +_enca=auto +_pthreads=auto +_ass=auto +_libass_osd=auto +_rpath=no +lua=auto +libpostproc=auto +libavfilter=auto +vf_lavfi=auto +af_lavfi=auto +libavdevice=auto +_stream_cache=yes +_priority=no +def_dos_paths="#define HAVE_DOS_PATHS 0" +def_priority="#define HAVE_PRIORITY 0" +_build_man=auto +_build_pdf=auto +_build_date=yes +for ac_option do + case "$ac_option" in + --help|-help|-h) + show_help + ;; + --prefix=*) + _prefix=$(echo $ac_option | cut -d '=' -f 2) + ;; + --bindir=*) + _bindir=$(echo $ac_option | cut -d '=' -f 2) + ;; + --mandir=*) + _mandir=$(echo $ac_option | cut -d '=' -f 2) + ;; + --docdir=*) + _docdir=$(echo $ac_option | cut -d '=' -f 2) + ;; + --confdir=*) + _confdir=$(echo $ac_option | cut -d '=' -f 2) + ;; + + --with-install=*) + _install=$(echo $ac_option | cut -d '=' -f 2 ) + ;; + + --extra-cflags=*) + extra_cflags="$extra_cflags $(echo $ac_option | cut -d '=' -f 2-)" + ;; + --extra-ldflags=*) + extra_ldflags="$extra_ldflags $(echo $ac_option | cut -d '=' -f 2-)" + ;; + --extra-libs=*) + extra_libs=$(echo $ac_option | cut -d '=' -f 2) + ;; + --extra-libs-mpv=*) + libs_mplayer=$(echo $ac_option | cut -d '=' -f 2) + ;; + + --target=*) + _target=$(echo $ac_option | cut -d '=' -f 2) + ;; + --cc=*) + _cc=$(echo $ac_option | cut -d '=' -f 2) + ;; + --pkg-config=*) + _pkg_config=$(echo $ac_option | cut -d '=' -f 2) + ;; + --windres=*) + _windres=$(echo $ac_option | cut -d '=' -f 2) + ;; + + --enable-static) + _ld_static='-static' + ;; + --disable-static) + _ld_static='' + ;; + --enable-debug) + _debug='-g' + ;; + --enable-debug=*) + _debug=$(echo $_echo_n '-g'$_echo_c; echo $ac_option | cut -d '=' -f 2) + ;; + --disable-debug) + _debug= + ;; + --enable-optimization) + _opt='-O2' + ;; + --enable-optimization=*) + _opt=$(echo $_echo_n '-O'$_echo_c; echo $ac_option | cut -d '=' -f 2) + ;; + --disable-optimization) + _opt= + ;; + --enable-cross-compile) _cross_compile=yes ;; + --disable-cross-compile) _cross_compile=no ;; + --enable-encoding) _encoding=yes ;; + --disable-encoding) _encoding=no ;; + --enable-wayland) _wayland=yes ;; + --disable-wayland) _wayland=no ;; + --enable-x11) _x11=yes ;; + --disable-x11) _x11=no ;; + --enable-xss) _xss=yes ;; + --disable-xss) _xss=no ;; + --enable-xv) _xv=yes ;; + --disable-xv) _xv=no ;; + --enable-vdpau) _vdpau=yes ;; + --disable-vdpau) _vdpau=no ;; + --enable-vda) _vda=yes ;; + --disable-vda) _vda=no ;; + --enable-vaapi) _vaapi=yes ;; + --disable-vaapi) _vaapi=no ;; + --enable-direct3d) _direct3d=yes ;; + --disable-direct3d) _direct3d=no ;; + --enable-sdl) _sdl=yes ;; + --disable-sdl) _sdl=no ;; + --enable-sdl2) _sdl2=yes ;; + --disable-sdl2) _sdl2=no ;; + --enable-dsound) _dsound=yes ;; + --disable-dsound) _dsound=no ;; + --enable-wasapi) _wasapi=yes ;; + --disable-wasapi) _wasapi=no ;; + --enable-jpeg) _jpeg=yes ;; + --disable-jpeg) _jpeg=no ;; + --enable-gl) _gl=yes ;; + --disable-gl) _gl=no ;; + --enable-caca) _caca=yes ;; + --disable-caca) _caca=no ;; + --enable-dvb) _dvb=yes ;; + --disable-dvb) _dvb=no ;; + --enable-iconv) _iconv=yes ;; + --disable-iconv) _iconv=no ;; + --enable-ossaudio) _ossaudio=yes ;; + --disable-ossaudio) _ossaudio=no ;; + --enable-rsound) _rsound=yes ;; + --disable-rsound) _rsound=no ;; + --enable-sndio) _sndio=yes ;; + --disable-sndio) _sndio=no ;; + --enable-pulse) _pulse=yes ;; + --disable-pulse) _pulse=no ;; + --enable-portaudio) _portaudio=yes ;; + --disable-portaudio) _portaudio=no ;; + --enable-jack) _jack=yes ;; + --disable-jack) _jack=no ;; + --enable-openal) _openal=auto ;; + --disable-openal) _openal=no ;; + --enable-libcdio) _libcdio=yes ;; + --disable-libcdio) _libcdio=no ;; + --enable-mpg123) _mpg123=yes ;; + --disable-mpg123) _mpg123=no ;; + --enable-ladspa) _ladspa=yes ;; + --disable-ladspa) _ladspa=no ;; + --enable-libbs2b) _libbs2b=yes ;; + --disable-libbs2b) _libbs2b=no ;; + --enable-vcd) _vcd=yes ;; + --disable-vcd) _vcd=no ;; + --enable-bluray) _bluray=yes ;; + --disable-bluray) _bluray=no ;; + --enable-dvdread) _dvdread=yes ;; + --disable-dvdread) _dvdread=no ;; + --enable-lcms2) _lcms2=yes ;; + --disable-lcms2) _lcms2=no ;; + --enable-xinerama) _xinerama=yes ;; + --disable-xinerama) _xinerama=no ;; + --enable-vm) _vm=yes ;; + --disable-vm) _vm=no ;; + --enable-xf86keysym) _xf86keysym=yes ;; + --disable-xf86keysym) _xf86keysym=no ;; + --enable-alsa) _alsa=yes ;; + --disable-alsa) _alsa=no ;; + --enable-tv) _tv=yes ;; + --disable-tv) _tv=no ;; + --enable-tv-v4l2) _tv_v4l2=yes ;; + --disable-tv-v4l2) _tv_v4l2=no ;; + --enable-libv4l2) _libv4l2=yes ;; + --disable-libv4l2) _libv4l2=no ;; + --enable-radio) _radio=yes ;; + --enable-radio-capture) _radio_capture=yes ;; + --disable-radio-capture) _radio_capture=no ;; + --disable-radio) _radio=no ;; + --enable-radio-v4l2) _radio_v4l2=yes ;; + --disable-radio-v4l2) _radio_v4l2=no ;; + --enable-pvr) _pvr=yes ;; + --disable-pvr) _pvr=no ;; + --enable-smb) _smb=yes ;; + --disable-smb) _smb=no ;; + --enable-libquvi4) _libquvi4=yes ;; + --disable-libquvi4) _libquvi4=no ;; + --enable-libquvi9) _libquvi9=yes ;; + --disable-libquvi9) _libquvi9=no ;; + --enable-libguess) _libguess=yes ;; + --disable-libguess) _libguess=no ;; + --enable-joystick) _joystick=yes ;; + --disable-joystick) _joystick=no ;; + --enable-libav) ffmpeg=yes ;; + --disable-libavresample) _disable_avresample=yes ;; + --enable-libavresample) _disable_avresample=no ;; + + --enable-lua) lua=yes ;; + --disable-lua) lua=no ;; + --lua=*) lua_pkg=$(echo $ac_option | cut -d '=' -f 2) ;; + --enable-lirc) _lirc=yes ;; + --disable-lirc) _lirc=no ;; + --enable-lircc) _lircc=yes ;; + --disable-lircc) _lircc=no ;; + --enable-terminfo) _terminfo=yes ;; + --disable-terminfo) _terminfo=no ;; + --enable-termcap) _termcap=yes ;; + --disable-termcap) _termcap=no ;; + --enable-termios) _termios=yes ;; + --disable-termios) _termios=no ;; + --enable-shm) _shm=yes ;; + --disable-shm) _shm=no ;; + --enable-select) _select=yes ;; + --disable-select) _select=no ;; + --enable-pthreads) _pthreads=yes ;; + --disable-pthreads) _pthreads=no ;; + --enable-libass) _ass=yes ;; + --disable-libass) _ass=no ;; + --enable-libass-osd) _libass_osd=yes ;; + --disable-libass-osd) _libass_osd=no ;; + --enable-rpath) _rpath=yes ;; + --disable-rpath) _rpath=no ;; + --enable-libpostproc) libpostproc=yes ;; + --disable-libpostproc) libpostproc=no ;; + --enable-libavdevice) libavdevice=auto ;; + --disable-libavdevice) libavdevice=no ;; + --enable-libavfilter) libavfilter=auto ;; + --disable-libavfilter) libavfilter=no ;; + --enable-vf-lavfi) vf_lavfi=auto ;; + --disable-vf-lavfi) vf_lavfi=no ;; + --enable-af-lavfi) af_lavfi=auto ;; + --disable-af-lavfi) af_lavfi=no ;; + + --enable-enca) _enca=yes ;; + --disable-enca) _enca=no ;; + + --enable-coreaudio) _coreaudio=yes ;; + --disable-coreaudio) _coreaudio=no ;; + --enable-corevideo) _corevideo=yes ;; + --disable-corevideo) _corevideo=no ;; + --enable-cocoa) _cocoa=yes ;; + --disable-cocoa) _cocoa=no ;; + + --enable-manpage) _build_man=yes ;; + --disable-manpage) _build_man=no ;; + --enable-pdf) _build_pdf=yes ;; + --disable-pdf) _build_pdf=no ;; + + --enable-build-date) _build_date=yes ;; + --disable-build-date) _build_date=no ;; + *) + echo "Unknown parameter: $ac_option" >&2 + exit 1 + ;; + + esac +done + +# Atmos: moved this here, to be correct, if --prefix is specified +test -z "$_bindir" && _bindir="$_prefix/bin" +test -z "$_mandir" && _mandir="$_prefix/share/man" +test -z "$_docdir" && _docdir="$_prefix/share/doc/mpv" +test -z "$_confdir" && _confdir="$_prefix/etc/mpv" + +for tmpdir in "$TMPDIR" "$TEMPDIR" "/tmp" ; do + test "$tmpdir" && break +done + +mplayer_tmpdir="$tmpdir/mpv-configure-$RANDOM-$$" +mkdir $mplayer_tmpdir || die "Unable to create tmpdir." + +TMPLOG="config.log" + +rm -f "$TMPLOG" +echo Parameters configure was run with: > "$TMPLOG" +if test -n "$CFLAGS" ; then + echo ${_echo_n} CFLAGS="'$CFLAGS' ${_echo_c}" >> "$TMPLOG" +fi +if test -n "$PKG_CONFIG_PATH" ; then + echo ${_echo_n} PKG_CONFIG_PATH="'$PKG_CONFIG_PATH' ${_echo_c}" >> "$TMPLOG" +fi +echo ./configure $configuration >> "$TMPLOG" +echo >> "$TMPLOG" + + +echocheck "cross compilation" +echores $_cross_compile + +if test $_cross_compile = yes; then + tmp_run() { + return 0 + } +fi + +tool_prefix="" + +if test $_cross_compile = yes ; then + # Usually cross-compiler prefixes match with the target triplet + test -n "$_target" && tool_prefix="$_target"- +fi + +test "$_windres" = auto && _windres="$tool_prefix"windres +test "$_pkg_config" = auto && _pkg_config="$tool_prefix"pkg-config + +if test "$_cc" = auto ; then + if test -n "$tool_prefix" ; then + _cc="$tool_prefix"gcc + else + _cc=cc + fi +fi + +# Determine our OS name and CPU architecture +if test -z "$_target" ; then + # OS name + system_name=$(uname -s 2>&1) + case "$system_name" in + Linux|FreeBSD|NetBSD|OpenBSD|DragonFly|Darwin|GNU|MorphOS) + ;; + Haiku) + system_name=Haiku + ;; + GNU/kFreeBSD) + system_name=FreeBSD + ;; + [cC][yY][gG][wW][iI][nN]*) + system_name=CYGWIN + ;; + MINGW32*) + system_name=MINGW32 + ;; + *) + system_name="$system_name-UNKNOWN" + ;; + esac + + + # host's CPU/instruction set + host_arch=$(uname -p 2>&1) + case "$host_arch" in + i386|sparc|ppc|alpha|arm|mips|vax) + ;; + powerpc) # Darwin returns 'powerpc' + host_arch=ppc + ;; + *) # uname -p on Linux returns 'unknown' for the processor type, + # OpenBSD returns 'Intel Pentium/MMX ("Genuine Intel" 586-class)' + + # Maybe uname -m (machine hardware name) returns something we + # recognize. + + case "$(uname -m 2>&1)" in + x86_64|amd64|i[3-9]86*|k5|k6|k6_2|k6_3|k6-2|k6-3|pentium*|athlon*|i586_i686|i586-i686|BePC) host_arch=i386 ;; + ia64) host_arch=ia64 ;; + macppc|ppc) host_arch=ppc ;; + ppc64) host_arch=ppc64 ;; + alpha) host_arch=alpha ;; + sparc) host_arch=sparc ;; + sparc64) host_arch=sparc64 ;; + parisc*|hppa*|9000*) host_arch=hppa ;; + arm*|zaurus|cats) host_arch=arm ;; + sh3|sh4|sh4a) host_arch=sh ;; + s390) host_arch=s390 ;; + s390x) host_arch=s390x ;; + *mips*) host_arch=mips ;; + vax) host_arch=vax ;; + xtensa*) host_arch=xtensa ;; + *) host_arch=UNKNOWN ;; + esac + ;; + esac +else # if test -z "$_target" + for i in 2 3; do + system_name=$(echo $_target | cut -d '-' -f $i) + case "$(echo $system_name | tr A-Z a-z)" in + linux) system_name=Linux ;; + freebsd) system_name=FreeBSD ;; + gnu/kfreebsd) system_name=FreeBSD ;; + netbsd) system_name=NetBSD ;; + openbsd) system_name=OpenBSD ;; + dragonfly) system_name=DragonFly ;; + morphos) system_name=MorphOS ;; + mingw32*) system_name=MINGW32 ;; + *) continue ;; + esac + break + done + # We need to convert underscores so that values like k6-2 and pentium-mmx can be passed + host_arch=$(echo $_target | cut -d '-' -f 1) + if test $(echo $host_arch) != "x86_64" ; then + host_arch=$(echo $host_arch | tr '_' '-') + fi +fi + +extra_cflags="-I. -D_GNU_SOURCE $extra_cflags" +_timer=timer-linux.c +_getch=getch2.c + +if freebsd ; then + extra_ldflags="$extra_ldflags -L/usr/local/lib" + extra_cflags="$extra_cflags -I/usr/local/include" +fi + +if netbsd || dragonfly ; then + extra_ldflags="$extra_ldflags -L/usr/pkg/lib" + extra_cflags="$extra_cflags -I/usr/pkg/include" +fi + +if darwin; then + extra_cflags="-mdynamic-no-pic $extra_cflags" + _timer=timer-darwin.c +fi + +_win32=no +if win32 ; then + _win32=yes + _exesuf=".exe" + extra_cflags="$extra_cflags -fno-common" + # -lwinmm is always needed for osdep/timer-win2.c + libs_mplayer="$libs_mplayer -lwinmm" + _pe_executable=yes + _timer=timer-win2.c + _priority=yes + def_dos_paths="#define HAVE_DOS_PATHS 1" + def_priority="#define HAVE_PRIORITY 1" +fi + +if mingw32 ; then + _getch=getch2-win.c + extra_cflags="$extra_cflags -D__USE_MINGW_ANSI_STDIO=1" + # Hack for missing BYTE_ORDER declarations in . + # (For some reason, they are in , but we don't bother switching + # the includes based on whether we're compiling for MinGW.) + extra_cflags="$extra_cflags -DBYTE_ORDER=1234 -DLITTLE_ENDIAN=1234 -DBIG_ENDIAN=4321" +fi + +if cygwin ; then + extra_cflags="$extra_cflags -mwin32" +fi + +_rst2man=rst2man +if [ -f "$(which rst2man.py)" ] ; then + _rst2man=rst2man.py +fi + +echocheck "whether to build manpages with rst2man" +if test "$_build_man" = auto ; then + _build_man=no + command_check "$_rst2man" --version && _build_man=yes +else + _build_man=no +fi +echores "$_build_man" + +_rst2latex=rst2latex +if [ -f "$(which rst2latex.py)" ] ; then + _rst2latex=rst2latex.py +fi + +echocheck "whether to build manual PDFs with rst2latex" +texcheck() { + echo test | $_rst2latex --config=DOCS/man/docutils.conf | pdflatex -halt-on-error -draftmode -output-directory="$mplayer_tmpdir" +} + +if test "$_build_pdf" = auto ; then + _build_pdf=no + command_check texcheck && _build_pdf=yes +else + _build_pdf=no +fi +echores "$_build_pdf" + +echocheck "whether to print binary build date" +if test "$_build_date" = yes ; then + _build_yes=yes +else + _build_date=no + extra_cflags="$extra_cflags -DNO_BUILD_TIMESTAMPS" +fi +echores "$_build_date" + + + +TMPC="$mplayer_tmpdir/tmp.c" +TMPCPP="$mplayer_tmpdir/tmp.cpp" +TMPEXE="$mplayer_tmpdir/tmp$_exesuf" +TMPH="$mplayer_tmpdir/tmp.h" +TMPS="$mplayer_tmpdir/tmp.S" + +# Checking CC version... +# Intel C++ Compilers (no autoselect, use CC=/some/binary ./configure) +if test "$(basename $_cc)" = "icc" || test "$(basename $_cc)" = "ecc"; then + echocheck "$_cc version" + cc_vendor=intel + cc_name=$($_cc -V 2>&1 | head -n 1 | cut -d ',' -f 1) + cc_version=$($_cc -V 2>&1 | head -n 1 | cut -d ',' -f 2 | cut -d ' ' -f 3) + _cc_major=$(echo $cc_version | cut -d '.' -f 1) + _cc_minor=$(echo $cc_version | cut -d '.' -f 2) + # TODO verify older icc/ecc compatibility + case $cc_version in + '') + cc_version="v. ?.??, bad" + cc_fail=yes + ;; + 10.1|11.0|11.1) + cc_version="$cc_version, ok" + ;; + *) + cc_version="$cc_version, bad" + cc_fail=yes + ;; + esac + echores "$cc_version" +else + for _cc in "$_cc" gcc cc ; do + cc_name_tmp=$($_cc -v 2>&1 | tail -n 1 | cut -d ' ' -f 1) + if test "$cc_name_tmp" = "gcc"; then + cc_name=$cc_name_tmp + echocheck "$_cc version" + cc_vendor=gnu + cc_version=$($_cc -dumpversion 2>&1) + case $cc_version in + 2.96*) + cc_fail=yes + ;; + *) + _cc_major=$(echo $cc_version | cut -d '.' -f 1) + _cc_minor=$(echo $cc_version | cut -d '.' -f 2) + _cc_mini=$(echo $cc_version | cut -d '.' -f 3) + ;; + esac + echores "$cc_version" + break + fi + if $_cc -v 2>&1 | grep -q "clang"; then + echocheck "$_cc version" + cc_vendor=clang + cc_version=$($_cc -dumpversion 2>&1) + res_comment="experimental support only" + echores "clang $cc_version" + break + fi + cc_name_tmp=$($_cc -V 2>&1 | head -n 1 | cut -d ' ' -f 2,3) + done +fi # icc +test "$cc_fail" = yes && die "unsupported compiler version" + +echocheck "working compiler" +cflag_check "" || die "Compiler is not functioning correctly. Check your installation and custom CFLAGS $CFLAGS ." +echo "yes" + +echocheck "perl" +command_check perl -Mv5.8 -e';' || die "Perl is not functioning correctly or is ancient. Install the latest perl available." +echo yes + +if test -z "$_target" && x86 ; then + cat > $TMPC << EOF +int main(void) { + int test[(int)sizeof(char *)-7]; + return 0; +} +EOF + cc_check && host_arch=x86_64 || host_arch=i386 +fi + +echo "Detected operating system: $system_name" +echo "Detected host architecture: $host_arch" + +# --- + +# now that we know what compiler should be used for compilation, try to find +# out which assembler is used by the $_cc compiler +if test "$_as" = auto ; then + _as=$($_cc -print-prog-name=as) + test -z "$_as" && _as=as +fi + +def_fast_64bit='#define HAVE_FAST_64BIT 0' +def_arch_x86='#define ARCH_X86 0' +def_arch_x86_32='#define ARCH_X86_32 0' +def_arch_x86_64='#define ARCH_X86_64 0' + +case "$host_arch" in + i[3-9]86|x86|x86pc|k5|k6|k6-2|k6-3|pentium*|athlon*|i586-i686) + arch='x86' + subarch='x86_32' + def_arch_x86='#define ARCH_X86 1' + def_arch_x86_32='#define ARCH_X86_32 1' + ;; + + ia64) + arch='ia64' + def_fast_64bit='#define HAVE_FAST_64BIT 1' + ;; + + x86_64|amd64) + arch='x86' + subarch='x86_64' + def_arch_x86='#define ARCH_X86 1' + def_arch_x86_64='#define ARCH_X86_64 1' + def_fast_64bit='#define HAVE_FAST_64BIT 1' + ;; + + sparc|sparc64) + arch='sparc' + ;; + + arm*) + arch='arm' + ;; + + avr32) + arch='avr32' + ;; + + sh|sh4) + arch='sh4' + ;; + + ppc|ppc64|powerpc|powerpc64) + arch='ppc' + ;; + + alpha*) + arch='alpha' + ;; + + mips*) + arch='mips' + ;; + + hppa) + arch='pa_risc' + ;; + + s390) + arch='s390' + ;; + + s390x) + arch='s390x' + ;; + + vax) + arch='vax' + ;; + + xtensa) + arch='xtensa' + ;; + + generic) + arch='generic' + ;; + + *) + echo "The architecture of your CPU ($host_arch) is not supported by this configure script" + echo "It seems nobody has ported mpv to your OS or CPU type yet." + die "unsupported architecture $host_arch" + ;; +esac # case "$host_arch" in + +echocheck "assembler support of -pipe option" +# -I. helps to detect compilers that just misunderstand -pipe like Sun C +cflag_check -pipe -I. && _pipe="-pipe" && echores "yes" || echores "no" + +# Checking for CFLAGS +if test -z "$CFLAGS" ; then + if test "$cc_vendor" = "intel" ; then + CFLAGS="$_opt $_debug $_pipe" + WARNFLAGS="-wd167 -wd556 -wd144" + elif test "$cc_vendor" = "clang"; then + CFLAGS="$_opt $_debug $_pipe" + WARNFLAGS="-Wall -Wno-switch -Wno-logical-op-parentheses -Wpointer-arith -Wundef -Wno-pointer-sign -Wmissing-prototypes -Wshadow" + ERRORFLAGS="-Werror=implicit-function-declaration -Wno-error=deprecated-declarations -Wno-error=unused-function" + elif test "$cc_vendor" != "gnu" ; then + CFLAGS="$_opt $_debug $_pipe" + else + CFLAGS="$_opt $_debug $_pipe" + WARNFLAGS="-Wall -Wno-switch -Wno-parentheses -Wpointer-arith -Wredundant-decls" + ERRORFLAGS="-Werror-implicit-function-declaration -Wno-error=deprecated-declarations -Wno-error=unused-function -Wshadow" + extra_ldflags="$extra_ldflags" + fi +else + warn_cflags=yes +fi + +if test "$cc_vendor" = "gnu" ; then + cflag_check -Wundef && WARNFLAGS="-Wundef $WARNFLAGS" + # -std=gnu99 is not a warning flag but is placed in WARN_CFLAGS because + # that's the only variable specific to C now, and this option is not valid + # for C++. + cflag_check -std=gnu99 && WARN_CFLAGS="-std=gnu99 $WARN_CFLAGS" + cflag_check -Wno-pointer-sign && WARN_CFLAGS="-Wno-pointer-sign $WARN_CFLAGS" + cflag_check -Wdisabled-optimization && WARN_CFLAGS="-Wdisabled-optimization $WARN_CFLAGS" + cflag_check -Wmissing-prototypes && WARN_CFLAGS="-Wmissing-prototypes $WARN_CFLAGS" + cflag_check -Wstrict-prototypes && WARN_CFLAGS="-Wstrict-prototypes $WARN_CFLAGS" +else + CFLAGS="-D_ISOC99_SOURCE -D_BSD_SOURCE $CFLAGS" +fi + +cflag_check -MD -MP && DEPFLAGS="-MD -MP" + + +if test -n "$LDFLAGS" ; then + extra_ldflags="$extra_ldflags $LDFLAGS" + warn_cflags=yes +elif test "$cc_vendor" = "intel" ; then + extra_ldflags="$extra_ldflags -i-static" +fi +if test -n "$CPPFLAGS" ; then + extra_cflags="$extra_cflags $CPPFLAGS" + warn_cflags=yes +fi + + +echocheck "PIC" +pic=no +cat > $TMPC << EOF +int main(void) { +#if !(defined(__PIC__) || defined(__pic__) || defined(PIC)) +#error PIC not enabled +#endif + return 0; +} +EOF +cc_check && pic=yes && extra_cflags="$extra_cflags -DPIC" +echores $pic + + +if x86 ; then + +echocheck "ebx availability" +ebx_available=no +def_ebx_available='#define HAVE_EBX_AVAILABLE 0' +cat > $TMPC << EOF +int main(void) { + int x; + __asm__ volatile( + "xor %0, %0" + :"=b"(x) + // just adding ebx to clobber list seems unreliable with some + // compilers, e.g. Haiku's gcc 2.95 + ); + // and the above check does not work for OSX 64 bit... + __asm__ volatile("":::"%ebx"); + return 0; +} +EOF +cc_check && ebx_available=yes && def_ebx_available='#define HAVE_EBX_AVAILABLE 1' +echores $ebx_available + +fi #if x86 + +###################### +# MAIN TESTS GO HERE # +###################### + + +echocheck "-lm" +if cflag_check -lm ; then + _ld_lm="-lm" + echores "yes" +else + _ld_lm="" + echores "no" +fi + + +echocheck "nanosleep" +_nanosleep=no +statement_check time.h 'nanosleep(0, 0)' && _nanosleep=yes +if test "$_nanosleep" = yes ; then + def_nanosleep='#define HAVE_NANOSLEEP 1' +else + def_nanosleep='#define HAVE_NANOSLEEP 0' +fi +echores "$_nanosleep" + + +echocheck "mman.h" +_mman=no +statement_check sys/mman.h 'mmap(0, 0, 0, 0, 0, 0)' && _mman=yes +if test "$_mman" = yes ; then + def_mman_h='#define HAVE_SYS_MMAN_H 1' +else + def_mman_h='#define HAVE_SYS_MMAN_H 0' +fi +echores "$_mman" + + +echocheck "dynamic loader" +_dl=no +for _ld_tmp in "" "-ldl"; do + statement_check dlfcn.h 'dlopen("", 0)' $_ld_tmp && _ld_dl="$_ld_tmp" && _dl=yes && break +done +if test "$_dl" = yes ; then + def_dl='#define HAVE_LIBDL 1' +else + def_dl='#define HAVE_LIBDL 0' +fi +echores "$_dl" + + +echocheck "pthread" +def_pthreads='#define HAVE_PTHREADS 0' +if linux ; then + THREAD_CFLAGS=-D_REENTRANT +elif freebsd || netbsd || openbsd ; then + THREAD_CFLAGS=-D_THREAD_SAFE +fi +if test "$_pthreads" = auto ; then +cat > $TMPC << EOF +#include +static void *func(void *arg) { return arg; } +int main(void) { + pthread_t tid; +#ifdef PTW32_STATIC_LIB + pthread_win32_process_attach_np(); + pthread_win32_thread_attach_np(); +#endif + return pthread_create (&tid, 0, func, 0) != 0; +} +EOF +_pthreads=no +for _ld_tmp in "-lpthreadGC2" "" "-lpthread" "-pthread" ; do +# for crosscompilation, we cannot execute the program, be happy if we can link statically +cc_check $THREAD_CFLAGS $_ld_tmp && (tmp_run || test "$_ld_static") && _ld_pthread="$_ld_tmp" && _pthreads=yes && break +done +if test "$_pthreads" = no && mingw32 ; then +_ld_tmp="-lpthreadGC2 -lws2_32" +cc_check $_ld_tmp -DPTW32_STATIC_LIB && (tmp_run || test "$_ld_static") && _ld_pthread="$_ld_tmp" && _pthreads=yes && CFLAGS="$CFLAGS -DPTW32_STATIC_LIB" +fi +fi +if test "$_pthreads" = yes ; then + test "$_ld_pthread" && res_comment="using $_ld_pthread" + def_pthreads='#define HAVE_PTHREADS 1' + extra_cflags="$extra_cflags $THREAD_CFLAGS" +else + res_comment="v4l2 disabled" + def_pthreads='#define HAVE_PTHREADS 0' + _tv_v4l2=no +fi +echores "$_pthreads" + +if test "$_pthreads" = yes ; then + +# Cargo-cult for -lrt, which is needed on not so recent glibc version for +# clock_gettime. It's documented as required before before glibc 2.17, which +# was released in december 2012. On newer glibc versions or on other systems, +# this will hopefully do nothing. +echocheck "linking with -lrt" +_rt=no +cc_check "$_ld_pthread -lrt" && _rt=yes +if test "$_rt" = yes ; then + _ld_pthread="$_ld_pthread -lrt" +fi +echores "$_rt" + +fi + +echocheck "stream cache" +_stream_cache="$_pthreads" +if test "$_stream_cache" = yes ; then + def_stream_cache='#define HAVE_STREAM_CACHE 1' +else + def_stream_cache='#define HAVE_STREAM_CACHE 0' +fi +echores "$_stream_cache" + +echocheck "rpath" +if test "$_rpath" = yes ; then + for I in $(echo $extra_ldflags | sed 's/-L//g') ; do + tmp="$tmp $(echo $I | sed 's/.*/ -L& -Wl,-R&/')" + done +extra_ldflags=$tmp +fi +echores "$_rpath" + +echocheck "iconv" +if test "$_iconv" = auto ; then + cat > $TMPC << EOF +#include +#include +#include +#define INBUFSIZE 1024 +#define OUTBUFSIZE 4096 + +char inbuffer[INBUFSIZE]; +char outbuffer[OUTBUFSIZE]; + +int main(void) { + size_t numread; + iconv_t icdsc; + char *tocode="UTF-8"; + char *fromcode="cp1250"; + if ((icdsc = iconv_open(tocode, fromcode)) != (iconv_t)(-1)) { + while ((numread = read(0, inbuffer, INBUFSIZE))) { + char *iptr=inbuffer; + char *optr=outbuffer; + size_t inleft=numread; + size_t outleft=OUTBUFSIZE; + if (iconv(icdsc, &iptr, &inleft, &optr, &outleft) + != (size_t)(-1)) { + write(1, outbuffer, OUTBUFSIZE - outleft); + } + } + if (iconv_close(icdsc) == -1) + ; + } + return 0; +} +EOF + _iconv=no + for _ld_tmp in "" "-liconv" "-liconv $_ld_dl" ; do + cc_check $_ld_lm $_ld_tmp && libs_mplayer="$libs_mplayer $_ld_tmp" && + _iconv=yes && break + done + if test "$_iconv" != yes ; then + die "Unable to find iconv which should be part of standard compilation environment. Aborting. If you really mean to compile without iconv support use --disable-iconv." + fi +fi +if test "$_iconv" = yes ; then + def_iconv='#define HAVE_ICONV 1' +else + def_iconv='#define HAVE_ICONV 0' +fi +echores "$_iconv" + + +echocheck "soundcard.h" +_soundcard_h=no +def_soundcard_h='#define HAVE_SOUNDCARD_H 0' +def_sys_soundcard_h='#define HAVE_SYS_SOUNDCARD_H 0' +for _soundcard_header in "sys/soundcard.h" "soundcard.h"; do + header_check $_soundcard_header && _soundcard_h=yes && + res_comment="$_soundcard_header" && break +done + +if test "$_soundcard_h" = yes ; then + if test $_soundcard_header = "sys/soundcard.h"; then + def_sys_soundcard_h='#define HAVE_SYS_SOUNDCARD_H 1' + else + def_soundcard_h='#define HAVE_SOUNDCARD_H 1' + fi +fi +echores "$_soundcard_h" + + +echocheck "sys/videoio.h" +sys_videoio_h=no +def_sys_videoio_h='#define HAVE_SYS_VIDEOIO_H 0' +header_check sys/videoio.h && sys_videoio_h=yes && + def_sys_videoio_h='#define HAVE_SYS_VIDEOIO_H 1' +echores "$sys_videoio_h" + + +echocheck "terminfo" +if test "$_terminfo" = auto ; then + _terminfo=no + for _ld_tmp in "-lncurses" "-lncursesw"; do + statement_check term.h 'setupterm(0, 1, 0)' $_ld_tmp && + libs_mplayer="$libs_mplayer $_ld_tmp" && _terminfo=yes && break + done +fi +if test "$_terminfo" = yes ; then + def_terminfo='#define HAVE_TERMINFO 1' + test $_ld_tmp && res_comment="using $_ld_tmp" + + if test "$_termcap" = auto ; then + _termcap=yes # terminfo provides termcap + fi +else + def_terminfo='#define HAVE_TERMINFO 0' +fi +echores "$_terminfo" + + +echocheck "termcap" +if test "$_termcap" = auto ; then + _termcap=no + for _ld_tmp in "-lncurses" "-ltinfo" "-ltermcap"; do + statement_check term.h 'tgetent(0, 0)' $_ld_tmp && + libs_mplayer="$libs_mplayer $_ld_tmp" && _termcap=yes && break + done +fi +if test "$_termcap" = yes ; then + def_termcap='#define HAVE_TERMCAP 1' + test $_ld_tmp && res_comment="using $_ld_tmp" +else + def_termcap='#define HAVE_TERMCAP 0' +fi +echores "$_termcap" + + +echocheck "termios" +def_termios='#define HAVE_TERMIOS 0' +def_termios_h='#define HAVE_TERMIOS_H 0' +def_termios_sys_h='#define HAVE_SYS_TERMIOS_H 0' +if test "$_termios" = auto ; then + _termios=no + for _termios_header in "termios.h" "sys/termios.h"; do + header_check $_termios_header && _termios=yes && + res_comment="using $_termios_header" && break +done +fi + +if test "$_termios" = yes ; then + def_termios='#define HAVE_TERMIOS 1' + if test "$_termios_header" = "termios.h" ; then + def_termios_h='#define HAVE_TERMIOS_H 1' + else + def_termios_sys_h='#define HAVE_SYS_TERMIOS_H 1' + fi +fi +echores "$_termios" + + +echocheck "shm" +if test "$_shm" = auto ; then + _shm=no + statement_check sys/shm.h 'shmget(0, 0, 0); shmat(0, 0, 0); shmctl(0, 0, 0)' && _shm=yes +fi +if test "$_shm" = yes ; then + def_shm='#define HAVE_SHM 1' +else + def_shm='#define HAVE_SHM 0' +fi +echores "$_shm" + + +echocheck "POSIX select()" +cat > $TMPC << EOF +#include +#include +#include +#include +#include +#include +int main(void) {int nfds = 1; fd_set readfds; struct timeval timeout; select(nfds, &readfds, NULL, NULL, &timeout); return 0; } +EOF +_posix_select=no +def_posix_select='#define HAVE_POSIX_SELECT 0' +cc_check && _posix_select=yes && + def_posix_select='#define HAVE_POSIX_SELECT 1' +echores "$_posix_select" + + +echocheck "audio select()" +if test "$_select" = no ; then + def_select='#define HAVE_AUDIO_SELECT 0' +elif test "$_select" = yes ; then + def_select='#define HAVE_AUDIO_SELECT 1' +fi +echores "$_select" + + +echocheck "glob()" +_glob=no +statement_check glob.h 'glob("filename", 0, 0, 0)' && _glob=yes +need_glob=no +if test "$_glob" = yes ; then + def_glob='#define HAVE_GLOB 1' +else + def_glob='#define HAVE_GLOB 0' + # HACK! need_glob currently enables compilation of a + # win32-specific glob()-replacement. + # Other OS neither need it nor can they use it (mf:// is disabled for them). + win32 && need_glob=yes +fi +echores "$_glob" + + +echocheck "setmode()" +_setmode=no +def_setmode='#define HAVE_SETMODE 0' +statement_check io.h 'setmode(0, 0)' && _setmode=yes && def_setmode='#define HAVE_SETMODE 1' +echores "$_setmode" + + +echocheck "sys/sysinfo.h" +_sys_sysinfo=no +statement_check sys/sysinfo.h 'struct sysinfo s_info; s_info.mem_unit=0; sysinfo(&s_info)' && _sys_sysinfo=yes +if test "$_sys_sysinfo" = yes ; then + def_sys_sysinfo_h='#define HAVE_SYS_SYSINFO_H 1' +else + def_sys_sysinfo_h='#define HAVE_SYS_SYSINFO_H 0' +fi +echores "$_sys_sysinfo" + + +echocheck "pkg-config" +if $($_pkg_config --version > /dev/null 2>&1); then + if test "$_ld_static"; then + _pkg_config="$_pkg_config --static" + fi + echores "yes" +else + _pkg_config=false + echores "no" +fi + + +echocheck "libguess support" +if test "$_libguess" = auto ; then + _libguess=no + if pkg_config_add 'libguess >= 1.0' ; then + _libguess=yes + fi +fi +if test "$_libguess" = yes; then + def_libguess="#define HAVE_LIBGUESS 1" +else + def_libguess="#define HAVE_LIBGUESS 0" +fi +echores "$_libguess" + + +echocheck "Samba support (libsmbclient)" +if test "$_smb" = auto ; then + _smb=no + if pkg_config_add 'smbclient >= 0.2.0' ; then + _smb=yes + fi +fi +if test "$_smb" = yes; then + def_smb="#define HAVE_LIBSMBCLIENT 1" + inputmodules="smb $inputmodules" +else + def_smb="#define HAVE_LIBSMBCLIENT 0" + noinputmodules="smb $noinputmodules" +fi +echores "$_smb" + + +echocheck "libquvi 0.4.x support" +if test "$_libquvi4" = auto ; then + _libquvi4=no + if pkg_config_add 'libquvi >= 0.4.1' ; then + _libquvi4=yes + fi +fi +if test "$_libquvi4" = yes; then + def_libquvi4="#define HAVE_LIBQUVI4 1" +else + def_libquvi4="#define HAVE_LIBQUVI4 0" +fi +echores "$_libquvi4" + +echocheck "libquvi 0.9.x support" +if test "$_libquvi4" = yes ; then + _libquvi9=no + res_comment="using libquvi 0.4.x" +fi +if test "$_libquvi9" = auto ; then + _libquvi9=no + if pkg_config_add 'libquvi-0.9 >= 0.9.0' ; then + _libquvi9=yes + fi +fi +if test "$_libquvi9" = yes; then + def_libquvi9="#define HAVE_LIBQUVI9 1" +else + def_libquvi9="#define HAVE_LIBQUVI9 0" +fi +echores "$_libquvi9" + +######### +# VIDEO # +######### + + +if darwin; then + +echocheck "Cocoa" +if test "$_cocoa" = auto ; then + cat > $TMPC < +#include +int main(void) { + NSApplicationLoad(); +} +EOF + _cocoa=no + cc_check -framework IOKit -framework Cocoa -framework OpenGL && _cocoa=yes +fi +if test "$_cocoa" = yes ; then + libs_mplayer="$libs_mplayer -framework IOKit -framework Cocoa -framework OpenGL" + extra_ldflags="$extra_ldflags -fobjc-arc" # needed for OS X 10.7 + def_cocoa='#define HAVE_COCOA 1' +else + def_cocoa='#define HAVE_COCOA 0' +fi +echores "$_cocoa" + +echocheck "CoreVideo" +if test "$_cocoa" = yes && test "$_corevideo" = auto ; then + cat > $TMPC < +int main(void) { return 0; } +EOF + _corevideo=no + cc_check -framework Cocoa -framework QuartzCore -framework OpenGL && _corevideo=yes +fi +if test "$_corevideo" = yes ; then + vomodules="corevideo $vomodules" + libs_mplayer="$libs_mplayer -framework QuartzCore" + def_corevideo='#define HAVE_COREVIDEO 1' +else + novomodules="corevideo $novomodules" + def_corevideo='#define HAVE_COREVIDEO 0' +fi +echores "$_corevideo" + +depends_on_application_services(){ + test "$_corevideo" = yes +} + +else + def_cocoa='#define HAVE_COCOA 0' + def_corevideo='#define HAVE_COREVIDEO 0' +fi #if darwin + +_wlver="1.2.0" +echocheck "Wayland" +if test "$_wayland" = yes || test "$_wayland" = auto; then + _wayland="no" + pkg_config_add "wayland-client >= $_wlver wayland-cursor >= $_wlver xkbcommon >= 0.3.0" \ + && _wayland="yes" +fi +if test "$_wayland" = yes; then + res_comment="" + def_wayland='#define HAVE_WAYLAND 1' + vomodules="wayland $vomodules" +else + res_comment="version >= $_wlver" + def_wayland='#define HAVE_WAYLAND 0' + novomodules="wayland $novomodules" +fi +echores "$_wayland" +unset _wlver + +echocheck "X11" +if test "$_x11" = auto ; then + _x11="no" + pkg_config_add "x11" && _x11="yes" +fi +if test "$_x11" = yes ; then + def_x11='#define HAVE_X11 1' + vomodules="x11 $vomodules" +else + _x11=no + def_x11='#define HAVE_X11 0' + novomodules="x11 $novomodules" + res_comment="check if the dev(el) packages are installed" +fi +echores "$_x11" + +echocheck "Xss screensaver extensions" +if test "$_xss" = auto ; then + _xss=no + statement_check "X11/extensions/scrnsaver.h" 'XScreenSaverSuspend(NULL, True)' -lXss && _xss=yes +fi +if test "$_xss" = yes ; then + def_xss='#define HAVE_XSS 1' + libs_mplayer="$libs_mplayer -lXss" +else + def_xss='#define HAVE_XSS 0' +fi +echores "$_xss" + +echocheck "X extensions" +_xext=no +if test "$_x11" = yes ; then + pkg_config_add "xext" && _xext="yes" +fi +if test "$_xext" = yes ; then + def_xext='#define HAVE_XEXT 1' + echores "yes" +else + def_xext='#define HAVE_XEXT 0' + echores "no" +fi + +echocheck "Xv" +if test "$_xv" = auto && test "$_x11" = yes ; then + _xv=no + statement_check_broken X11/Xlib.h X11/extensions/Xvlib.h 'XvGetPortAttribute(0, 0, 0, 0)' -lXv && _xv=yes +fi + +if test "$_xv" = yes ; then + def_xv='#define HAVE_XV 1' + libs_mplayer="$libs_mplayer -lXv" + vomodules="xv $vomodules" +else + def_xv='#define HAVE_XV 0' + novomodules="xv $novomodules" +fi +echores "$_xv" + + +echocheck "VDPAU" +if test "$_vdpau" = auto && test "$_x11" = yes ; then + _vdpau=no + if test "$_dl" = yes ; then + pkg_config_add 'vdpau >= 0.2' && _vdpau=yes + fi +fi +if test "$_vdpau" = yes ; then + def_vdpau='#define HAVE_VDPAU 1' + vomodules="vdpau $vomodules" +else + def_vdpau='#define HAVE_VDPAU 0' + novomodules="vdpau $novomodules" +fi +echores "$_vdpau" + + +echocheck "VAAPI" +_vaapi_vpp=no +def_vaapi_vpp='#define HAVE_VAAPI_VPP 0' +_vaapi_glx=no +def_vaapi_glx='#define HAVE_VAAPI_GLX 0' +if test "$_vaapi" = auto && test "$_x11" = yes ; then + _vaapi=no + if test "$_dl" = yes ; then + pkg_config_add 'libva >= 0.32.0 libva-x11 >= 0.32.0' && _vaapi=yes + fi +fi +if test "$_vaapi" = yes ; then + def_vaapi='#define HAVE_VAAPI 1' + def_vaapi_hwaccel='#define HAVE_VAAPI_HWACCEL 1' + vomodules="vaapi $vomodules" +else + def_vaapi='#define HAVE_VAAPI 0' + def_vaapi_hwaccel='#define HAVE_VAAPI_HWACCEL 0' + novomodules="vaapi $novomodules" +fi +echores "$_vaapi" + +if test "$_vaapi" = yes ; then + echocheck "VAAPI VPP" + if pkg-config 'libva >= 0.34.0' ; then + _vaapi_vpp=yes + def_vaapi_vpp='#define HAVE_VAAPI_VPP 1' + fi + echores "$_vaapi_glx" + echocheck "VAAPI GLX" + if pkg_config_add 'libva-glx >= 0.32.0' ; then + _vaapi_glx=yes + def_vaapi_glx='#define HAVE_VAAPI_GLX 1' + fi + echores "$_vaapi_glx" +fi + + +echocheck "Xinerama" +if test "$_xinerama" = auto && test "$_x11" = yes ; then + _xinerama=no + statement_check X11/extensions/Xinerama.h 'XineramaIsActive(0)' -lXinerama && _xinerama=yes +fi + +if test "$_xinerama" = yes ; then + def_xinerama='#define HAVE_XINERAMA 1' + libs_mplayer="$libs_mplayer -lXinerama" +else + def_xinerama='#define HAVE_XINERAMA 0' +fi +echores "$_xinerama" + + +# Note: the -lXxf86vm library is the VideoMode extension and though it's not +# needed for DGA, AFAIK every distribution packages together with DGA stuffs +# named 'X extensions' or something similar. +# This check may be useful for future mplayer versions (to change resolution) +# If you run into problems, remove '-lXxf86vm'. +echocheck "Xxf86vm" +if test "$_vm" = auto && test "$_x11" = yes ; then + _vm=no + statement_check_broken X11/Xlib.h X11/extensions/xf86vmode.h 'XF86VidModeQueryExtension(0, 0, 0)' -lXxf86vm && _vm=yes +fi +if test "$_vm" = yes ; then + def_vm='#define HAVE_XF86VM 1' + libs_mplayer="$libs_mplayer -lXxf86vm" +else + def_vm='#define HAVE_XF86VM 0' +fi +echores "$_vm" + +# Check for the presence of special keycodes, like audio control buttons +# that XFree86 might have. Used to be bundled with the xf86vm check, but +# has nothing to do with xf86vm and XFree 3.x has xf86vm but does NOT +# have these new keycodes. +echocheck "XF86keysym" +if test "$_xf86keysym" = auto && test "$_x11" = yes ; then + _xf86keysym=no + return_check X11/XF86keysym.h XF86XK_AudioPause && _xf86keysym=yes +fi +if test "$_xf86keysym" = yes ; then + def_xf86keysym='#define HAVE_XF86XK 1' +else + def_xf86keysym='#define HAVE_XF86XK 0' +fi +echores "$_xf86keysym" + + +echocheck "CACA" +if test "$_caca" = auto ; then + _caca=no + pkg_config_add 'caca >= 0.99.beta18' && _caca=yes +fi +if test "$_caca" = yes ; then + def_caca='#define HAVE_CACA 1' + vomodules="caca $vomodules" +else + def_caca='#define HAVE_CACA 0' + novomodules="caca $novomodules" +fi +echores "$_caca" + + +echocheck "DVB" +if test "$_dvb" = auto ; then + _dvb=no +cat >$TMPC << EOF +#include +#include +#include +#include +#include +#include +#include +#include +#include +int main(void) {return 0;} +EOF + for _inc_tmp in "" "-I/usr/src/DVB/include" ; do + cc_check $_inc_tmp && _dvb=yes && + extra_cflags="$extra_cflags $_inc_tmp" && break + done +fi +echores "$_dvb" +if test "$_dvb" = yes ; then + _dvbin=yes + inputmodules="dvb $inputmodules" + def_dvb='#define HAVE_DVB 1' + def_dvbin='#define HAVE_DVBIN 1' +else + _dvbin=no + noinputmodules="dvb $noinputmodules" + def_dvb='#define HAVE_DVB 0' + def_dvbin='#define HAVE_DVBIN 0 ' +fi + + +echocheck "JPEG support" +if test "$_jpeg" = auto ; then + _jpeg=no + header_check_broken stdio.h jpeglib.h -ljpeg $_ld_lm && _jpeg=yes +fi +echores "$_jpeg" + +if test "$_jpeg" = yes ; then + def_jpeg='#define HAVE_JPEG 1' + libs_mplayer="$libs_mplayer -ljpeg" +else + def_jpeg='#define HAVE_JPEG 0' +fi + + +################# +# VIDEO + AUDIO # +################# + + +# make sure this stays below CoreVideo to avoid issues due to namespace +# conflicts between -lGL and -framework OpenGL +echocheck "OpenGL" +#Note: this test is run even with --enable-gl since we autodetect linker flags +if (test "$_x11" = yes || test "$_wayland" = yes || test "$_cocoa" = yes || win32) && test "$_gl" != no ; then + cat > $TMPC << EOF +#ifdef GL_WIN32 +#include +#elif defined(GL_WAYLAND) +#include +#else +#include +#include +#endif +#include +int main(int argc, char *argv[]) { +#ifdef GL_WIN32 + HDC dc; + wglCreateContext(dc); +#elif defined(GL_WAYLAND) + eglCreateContext(NULL, NULL, EGL_NO_CONTEXT, NULL); +#else + glXCreateContext(NULL, NULL, NULL, True); +#endif + glFinish(); + return 0; +} +EOF + _gl=no + if test "$_x11" = yes ; then + for _ld_tmp in "" -lGL "-lGL -lXdamage" "-lGL $_ld_pthread" ; do + if cc_check $_ld_tmp $_ld_lm ; then + _gl=yes + _gl_x11=yes + libs_mplayer="$libs_mplayer $_ld_tmp $_ld_dl" + break + fi + done + fi + if test "$_wayland" = yes && cc_check -DGL_WAYLAND -lGL -lEGL && + pkg_config_add "wayland-egl >= 9.0.0"; then + _gl=yes + _gl_wayland=yes + libs_mplayer="$libs_mplayer -lGL -lEGL" + fi + if win32 && cc_check -DGL_WIN32 -lopengl32 ; then + _gl=yes + _gl_win32=yes + libs_mplayer="$libs_mplayer -lopengl32 -lgdi32" + fi + if test "$_cocoa" = yes ; then + _gl=yes + _gl_cocoa=yes + fi + + cat > $TMPC << EOF +#ifdef __APPLE__ +#include +#include +#else +#include +#include +#endif +int main(int argc, char *argv[]) { + return !GL_INVALID_FRAMEBUFFER_OPERATION; +} +EOF + if ! cc_check; then + _gl=no + _gl_x11=no + _gl_wayland=no + _gl_win32=no + _gl_cocoa=no + res_comment="missing glext.h, get from http://www.opengl.org/registry/api/glext.h" + fi +else + _gl=no +fi + +def_gl_cocoa='#define HAVE_GL_COCOA 0' +def_gl_win32='#define HAVE_GL_WIN32 0' +def_gl_x11='#define HAVE_GL_X11 0' +def_gl_wayland='#define HAVE_GL_WAYLAND 0' + +if test "$_gl" = yes ; then + def_gl='#define HAVE_GL 1' + res_comment="backends:" + if test "$_gl_cocoa" = yes ; then + def_gl_cocoa='#define HAVE_GL_COCOA 1' + res_comment="$res_comment cocoa" + fi + if test "$_gl_win32" = yes ; then + def_gl_win32='#define HAVE_GL_WIN32 1' + res_comment="$res_comment win32" + fi + if test "$_gl_x11" = yes ; then + def_gl_x11='#define HAVE_GL_X11 1' + res_comment="$res_comment x11" + fi + if test "$_gl_wayland" = yes ; then + def_gl_wayland='#define HAVE_GL_WAYLAND 1' + res_comment="$res_comment wayland" + fi + vomodules="opengl $vomodules" +else + def_gl='#define HAVE_GL 0' + novomodules="opengl $novomodules" +fi +echores "$_gl" + + +echocheck "VDPAU with OpenGL/X11" +if test "$_gl_x11" = yes && test "$_vdpau" = yes ; then + def_vdpau_gl_x11='#define HAVE_VDPAU_GL_X11 1' + _vdpau_gl_x11=yes +else + def_vdpau_gl_x11='#define HAVE_VDPAU_GL_X11 0' + _vdpau_gl_x11=no +fi +echores "$_vdpau_gl_x11" + + +if win32; then + + +echocheck "Direct3D" +if test "$_direct3d" = auto ; then + _direct3d=no + header_check d3d9.h && _direct3d=yes +fi +if test "$_direct3d" = yes ; then + def_direct3d='#define HAVE_DIRECT3D 1' + vomodules="direct3d $vomodules" +else + def_direct3d='#define HAVE_DIRECT3D 0' + novomodules="direct3d $novomodules" +fi +echores "$_direct3d" + + +echocheck "DirectSound" +if test "$_dsound" = auto ; then + _dsound=no + header_check dsound.h && _dsound=yes +fi +if test "$_dsound" = yes ; then + def_dsound='#define HAVE_DSOUND 1' + aomodules="dsound $aomodules" +else + def_dsound='#define HAVE_DSOUND 0' + noaomodules="dsound $noaomodules" +fi +echores "$_dsound" + +echocheck "WASAPI" +if test "$_wasapi" = auto ; then + _wasapi=no + +cat > $TMPC << EOF +#define COBJMACROS 1 +#define _WIN32_WINNT 0x600 +#include +#include +#include +#include +#include +#include +#include +#include + const GUID *check1[] = { + &IID_IAudioClient, + &IID_IAudioRenderClient, + &IID_IAudioClient, + &IID_IAudioEndpointVolume, + }; +int main(void) { + return 0; +} +EOF + +if cc_check "-lole32"; then + _wasapi="yes" +fi + +fi +if test "$_wasapi" = yes ; then + def_wasapi='#define HAVE_WASAPI 1' + aomodules="wasapi $aomodules" + libs_mplayer="$libs_mplayer -lole32" +else + def_wasapi='#define HAVE_WASAPI 0' + noaomodules="wasapi $noaomodules" +fi +echores "$_wasapi" + +else + def_direct3d='#define HAVE_DIRECT3D 0' + def_dsound='#define HAVE_DSOUND 0' + def_wasapi='#define HAVE_WASAPI 0' +fi #if win32; then + + +echocheck "SDL 2.0" +if test "$_sdl2" = yes ; then + pkg_config_add 'sdl2' && _sdl2=yes +fi +if test "$_sdl2" = yes ; then + _sdl=yes # sdl2 implies sdl + def_sdl='#define HAVE_SDL 1' + def_sdl2='#define HAVE_SDL2 1' + vomodules="sdl $vomodules" + aomodules="sdl $aomodules" + echores "$_sdl2" +else + def_sdl2='#define HAVE_SDL2 0' + echores "$_sdl2" + echocheck "SDL" + if test "$_sdl" = yes ; then + pkg_config_add 'sdl' && _sdl=yes + fi + if test "$_sdl" = yes ; then + def_sdl='#define HAVE_SDL 1' + novomodules="sdl $novomodules" + aomodules="sdl $aomodules" + else + def_sdl='#define HAVE_SDL 0' + novomodules="sdl $novomodules" + noaomodules="sdl $noaomodules" + fi + echores "$_sdl" +fi + + + + +######### +# AUDIO # +######### + + +echocheck "OSS Audio" +if test "$_ossaudio" = auto ; then + _ossaudio=no + return_check $_soundcard_header SNDCTL_DSP_SETFRAGMENT && _ossaudio=yes +fi +if test "$_ossaudio" = yes ; then + def_ossaudio='#define HAVE_OSS_AUDIO 1' + aomodules="oss $aomodules" + cat > $TMPC << EOF +#include <$_soundcard_header> +#ifdef OPEN_SOUND_SYSTEM +int main(void) { return 0; } +#else +#error Not the real thing +#endif +EOF + _real_ossaudio=no + cc_check && _real_ossaudio=yes + if test "$_real_ossaudio" = yes; then + def_ossaudio_devdsp='#define PATH_DEV_DSP "/dev/dsp"' + # Check for OSS4 headers (override default headers) + # Does not apply to systems where OSS4 is native (e.g. FreeBSD) + if test -f /etc/oss.conf; then + . /etc/oss.conf + _ossinc="$OSSLIBDIR/include" + if test -f "$_ossinc/sys/soundcard.h"; then + extra_cflags="-I$_ossinc $extra_cflags" + fi + fi + elif netbsd || openbsd ; then + def_ossaudio_devdsp='#define PATH_DEV_DSP "/dev/sound"' + libs_mplayer="$libs_mplayer -lossaudio" + else + def_ossaudio_devdsp='#define PATH_DEV_DSP "/dev/dsp"' + fi + def_ossaudio_devmixer='#define PATH_DEV_MIXER "/dev/mixer"' +else + def_ossaudio='#define HAVE_OSS_AUDIO 0' + def_ossaudio_devdsp='#define PATH_DEV_DSP ""' + def_ossaudio_devmixer='#define PATH_DEV_MIXER ""' + noaomodules="oss $noaomodules" +fi +echores "$_ossaudio" + + +echocheck "RSound" +if test "$_rsound" = auto ; then + _rsound=no + statement_check rsound.h 'rsd_init(NULL);' -lrsound && _rsound=yes +fi +echores "$_rsound" + +if test "$_rsound" = yes ; then + def_rsound='#define HAVE_RSOUND 1' + aomodules="rsound $aomodules" + libs_mplayer="$libs_mplayer -lrsound" +else + def_rsound='#define HAVE_RSOUND 0' + noaomodules="rsound $noaomodules" +fi + + +echocheck "sndio" +if test "$_sndio" = auto ; then + _sndio=no + statement_check sndio.h 'struct sio_par par; sio_initpar(&par);' -lsndio && _sndio=yes +fi +echores "$_sndio" + +if test "$_sndio" = yes ; then + def_sndio='#define HAVE_SNDIO 1' + aomodules="snd