X-Git-Url: https://git.sesse.net/?a=blobdiff_plain;f=configure.in;h=1c0ba32a22527eca516db9d19012814989171357;hb=4945d2bb3621b899aca49359c435d0dcfcc2ec1b;hp=ca1736cc80dc4ac18e22845306280afce0c01121;hpb=c0138ec5ec4fd09b4421797c0edfaf8a56951d42;p=vlc diff --git a/configure.in b/configure.in index ca1736cc80..1c0ba32a22 100644 --- a/configure.in +++ b/configure.in @@ -1,63 +1,100 @@ -dnl Autoconf settings for vlc -AC_INIT(src/interface/main.c) +dnl Autoconf settings for vlc and libdvdcss +AC_INIT(include/main.h) AC_CONFIG_HEADER(include/defs.h) AC_CANONICAL_HOST -VLC_VERSION=0.2.72 +VLC_VERSION=0.2.81 AC_SUBST(VLC_VERSION) +LIBDVDCSS_VERSION=0.0.2 +AC_SUBST(LIBDVDCSS_VERSION) VLC_CODENAME=Ourumov AC_SUBST(VLC_CODENAME) +dnl Save CFLAGS +save_CFLAGS="${CFLAGS}" + dnl Check for tools AC_PROG_MAKE_SET AC_PROG_CC AC_PROG_CPP +AC_PROG_RANLIB dnl AM_PROG_LIBTOOL AC_PROG_INSTALL dnl Check for compiler environment AC_C_CONST -AC_C_BIGENDIAN + +dnl Check for endianness if not cross-compiling +if test x${cross_compiling} != xyes; then + AC_C_BIGENDIAN +fi dnl Check for system libs needed AC_CHECK_FUNCS(gettimeofday select strerror strtod strtol) AC_CHECK_FUNCS(setenv putenv) -AC_CHECK_FUNC(connect,,[AC_CHECK_LIB(socket,connect,LIB="${LIB} -lsocket")]) -AC_CHECK_FUNC(gethostbyname,,[AC_CHECK_LIB(nsl,gethostbyname,LIB="${LIB} -lnsl")]) -AC_CHECK_FUNC(nanosleep,,[AC_CHECK_LIB(rt,nanosleep,LIB="${LIB} -lrt",[AC_CHECK_LIB(posix4,nanosleep,LIB="${LIB} -lposix4")])]) +AC_CHECK_FUNC(connect,,[ + AC_CHECK_LIB(socket,connect,LIB="${LIB} -lsocket") +]) +AC_CHECK_FUNC(gethostbyname,,[ + AC_CHECK_LIB(nsl,gethostbyname,LIB="${LIB} -lnsl") +]) +AC_CHECK_FUNC(nanosleep,,[ + AC_CHECK_LIB(rt,nanosleep,LIB="${LIB} -lrt",[ + AC_CHECK_LIB(posix4,nanosleep,LIB="${LIB} -lposix4") + ]) +]) AC_CHECK_FUNCS(usleep) -AC_CHECK_FUNC(inet_aton,,[AC_CHECK_LIB(resolv,inet_aton,LIB="${LIB} -lresolv")]) +AC_CHECK_FUNC(inet_aton,,[ + AC_CHECK_LIB(resolv,inet_aton,LIB="${LIB} -lresolv") +]) AC_CHECK_FUNCS(vasprintf) +AC_CHECK_FUNCS(swab) + +AC_CHECK_FUNCS(sigrelse) +dnl Check for getopt +GETOPT=0 AC_CHECK_FUNC(getopt_long,[AC_DEFINE(HAVE_GETOPT_LONG,1,long getopt support)], [ # FreeBSD has a gnugetopt library for this: AC_CHECK_LIB([gnugetopt],[getopt_long], [AC_DEFINE(HAVE_GETOPT_LONG,1,getopt support) LIB="${LIB} -lgnugetopt"], [GETOPT=1])]) -AC_SUBST(GETOPT) AC_FUNC_MMAP AC_TYPE_SIGNAL AC_CHECK_LIB(dl,dlopen,LIB="${LIB} -ldl") AC_CHECK_LIB(m,pow,LIB_YUV="${LIB_YUV} -lm") -AC_MSG_CHECKING(for old style FreeBSD -pthread flag) -AC_EGREP_CPP(yes, - [#if defined(__FreeBSD_cc_version) && __FreeBSD_cc_version <= 500001 - yes - #endif - ], AC_MSG_RESULT(yes) - DEFINE="${DEFINE} -D_THREAD_SAFE" LIB="${LIB} -pthread", - AC_MSG_RESULT(no) - AC_CHECK_LIB(pthread,pthread_create,LIB="${LIB} -lpthread")) -AC_CHECK_LIB(threads,thread_create,LIB="${LIB} -lthreads") CPPFLAGS="${CPPFLAGS} -I/usr/local/include" -AC_CHECK_HEADERS(stddef.h) -AC_CHECK_HEADERS(getopt.h) -AC_CHECK_HEADERS(sys/sockio.h) -AC_CHECK_HEADERS(fcntl.h sys/time.h unistd.h) +CFLAGS="${CFLAGS} -I/usr/local/include" + +dnl Check for pthreads - borrowed from XMMS +PTHREAD_LIBS=error +AC_CHECK_LIB(pthread,pthread_attr_init,THREAD_LIB="-lpthread") +if test "x${THREAD_LIB}" = xerror; then + AC_CHECK_LIB(pthreads,pthread_attr_init,THREAD_LIB="-lpthreads") +fi +if test "x${THREAD_LIB}" = xerror; then + AC_CHECK_LIB(c_r,pthread_attr_init,THREAD_LIB="-lc_r") +fi +if test "x${THREAD_LIB}" = xerror; then + THREAD_LIBS="" + AC_CHECK_FUNC(pthread_attr_init) +fi + +dnl Check for misc headers +AC_EGREP_HEADER(pthread_cond_t,pthread.h,[ + AC_DEFINE(PTHREAD_COND_T_IN_PTHREAD_H, 1, + Define if defines pthread_cond_t.)]) +AC_EGREP_HEADER(strncasecmp,strings.h,[ + AC_DEFINE(STRNCASECMP_IN_STRINGS_H, 1, + Define if defines strncasecmp.)]) + +dnl Check for headers +AC_CHECK_HEADERS(stddef.h getopt.h strings.h) +AC_CHECK_HEADERS(sys/sockio.h fcntl.h sys/time.h unistd.h) AC_CHECK_HEADERS(sys/soundcard.h machine/soundcard.h) AC_CHECK_HEADERS(dlfcn.h image.h) AC_CHECK_HEADERS(arpa/inet.h net/if.h netinet/in.h sys/socket.h) @@ -66,26 +103,37 @@ AC_CHECK_HEADERS(machine/param.h) dnl Check for threads library AC_CHECK_HEADERS(cthreads.h pthread.h kernel/scheduler.h kernel/OS.h) -dnl Do a series of bizarre compilation tests -save_CFLAGS=$CFLAGS - dnl Check for ntohl, etc. -CFLAGS="${CFLAGS} -Wall -Werror" +CFLAGS="${save_CFLAGS} -Wall -Werror" AC_MSG_CHECKING([for ntohl in sys/param.h]) AC_TRY_COMPILE([#include void foo() { int meuh; ntohl(meuh); }],, - AC_DEFINE(NTOHL_IN_SYS_PARAM_H, 1, Define if ntohl is in .) + AC_DEFINE(NTOHL_IN_SYS_PARAM_H, 1, Define if defines ntohl.) AC_MSG_RESULT(yes), AC_MSG_RESULT(no)) -dnl Check for -rdynamic flag -CFLAGS="${CFLAGS} -rdynamic -Wall -Werror" -AC_MSG_CHECKING([if \$CC groks -rdynamic without complaining too much]) +dnl Check for inline function size limit +CFLAGS="${save_CFLAGS} -finline-limit=12" +AC_MSG_CHECKING([if \$CC accepts -finline-limit]) AC_TRY_COMPILE([],, - LCFLAGS="${LCFLAGS} -rdynamic" - AC_MSG_RESULT(yes), AC_MSG_RESULT(no)) + save_CFLAGS="${save_CFLAGS} -finline-limit=31337"; AC_MSG_RESULT(yes), + AC_MSG_RESULT(no)) + +dnl Check for Darwin plugin linking flags +CFLAGS="${save_CFLAGS} -bundle -undefined suppress" +AC_MSG_CHECKING([if \$CC compiles plugins with -bundle -undefined suppress]) +AC_TRY_COMPILE([],, + PLCFLAGS="${PLCFLAGS} -bundle -undefined suppress"; AC_MSG_RESULT(yes), + AC_MSG_RESULT(no)) + +dnl Check for standard plugin linking flags +CFLAGS="${save_CFLAGS} -shared" +AC_MSG_CHECKING([if \$CC compiles plugins with -shared]) +AC_TRY_COMPILE([],, + PLCFLAGS="${PLCFLAGS} -shared"; AC_MSG_RESULT(yes), + AC_MSG_RESULT(no)) dnl End of the bizarre compilation tests -CFLAGS=$save_CFLAGS +CFLAGS="${save_CFLAGS}" dnl Check for boolean_t AC_MSG_CHECKING([for boolean_t in sys/types.h]) @@ -109,53 +157,85 @@ ARCH=${host_cpu} dnl dnl default modules dnl -BUILTINS="${BUILTINS} es ps ts yuv idct idctclassic motion" -if test x$host_os = xbeos; then - ACCEL_PLUGINS="yuvmmx idctmmx motionmmx" -else - ACCEL_PLUGINS="yuvmmx idctmmx idctmmxext motionmmx motionmmxext" -fi +BUILTINS="${BUILTINS} es ps ts yuv idct idctclassic motion imdct downmix" +PLUGINS="${PLUGINS}" dnl -dnl DVD module: check for DVD ioctls +dnl Accelerated modules dnl -AC_CHECK_HEADERS(sys/ioctl.h,[ - BUILTINS="${BUILTINS} dvd" - AC_CHECK_HEADERS(linux/cdrom.h) - AC_EGREP_HEADER(dvd,linux/cdrom.h,[ - AC_DEFINE(LINUX_DVD,1, DVD support for linux) - ]) -]) +MMX_MODULES="yuvmmx idctmmx motionmmx" +MMXEXT_MODULES="idctmmxext motionmmxext imdct3dn imdctsse downmix3dn downmixsse" -dnl -dnl dummy plugin -dnl -AC_ARG_ENABLE(dummy, - [ --disable-dummy dummy module (default enabled)]) -if test x$enable_dummy != xno; then - BUILTINS="${BUILTINS} dummy"; fi +AC_MSG_CHECKING([if \$CC groks MMX inline assembly]) +AC_TRY_COMPILE([void quux(){void *p;asm("packuswb %%mm1,%%mm2"::"r"(p));}],, + ACCEL_MODULES="${ACCEL_MODULES} ${MMX_MODULES}" + AC_MSG_RESULT(yes), AC_MSG_RESULT(no)) + +AC_MSG_CHECKING([if \$CC groks MMX EXT or SSE inline assembly]) +AC_TRY_COMPILE([void quux(){void *p;asm("maskmovq %%mm1,%%mm2"::"r"(p));}],, + ACCEL_MODULES="${ACCEL_MODULES} ${MMXEXT_MODULES}" + AC_MSG_RESULT(yes), AC_MSG_RESULT(no)) dnl -dnl null plugin +dnl libdvdcss: check for DVD ioctls dnl -AC_ARG_ENABLE(null, - [ --disable-null Null module (default enabled)]) -if test x$enable_null != xno; then - BUILTINS="${BUILTINS} null"; fi + +dnl for windoze +AC_CHECK_HEADERS(winioctl.h,[ + CAN_BUILD_LIBDVDCSS=1 +]) + +dnl for Un*x +AC_CHECK_HEADERS(sys/ioctl.h,[ + CAN_BUILD_LIBDVDCSS=1 + AC_CHECK_HEADERS(sys/cdio.h sys/dvdio.h linux/cdrom.h) + BSD_DVD_STRUCT=0 + dnl + dnl Old FreeBSD: sys/cdio.h + dnl + AC_EGREP_HEADER(dvd_struct,sys/dvdio.h,[ + AC_DEFINE(DVD_STRUCT_IN_SYS_DVDIO_H, 1, + Define if defines dvd_struct.) + BSD_DVD_STRUCT=1 + ]) + dnl + dnl Newer FreeBSD: sys/dvdio.h + dnl + AC_EGREP_HEADER(dvd_struct,sys/cdio.h,[ + AC_DEFINE(DVD_STRUCT_IN_SYS_CDIO_H, 1, + Define if defines dvd_struct.) + BSD_DVD_STRUCT=1 + ]) + if test x$BSD_DVD_STRUCT = x1; then + AC_DEFINE(HAVE_BSD_DVD_STRUCT, 1, + Define if BSD-like dvd_struct is defined.) + fi + dnl + dnl Linux: linux/cdrom.h + dnl + AC_EGREP_HEADER(dvd_struct,linux/cdrom.h,[ + AC_DEFINE(DVD_STRUCT_IN_LINUX_CDROM_H, 1, + Define if defines DVD_STRUCT.) + ]) +]) dnl -dnl rc plugin +dnl Check the operating system dnl -AC_ARG_ENABLE(rc, - [ --disable-rc rc module (default enabled)]) -if test x$enable_rc != xno; then - BUILTINS="${BUILTINS} rc"; fi +case ${host_os} in + darwin*) + SYS=darwin + ;; + *) + SYS=${host_os} + ;; +esac dnl dnl PentiumPro acceleration dnl AC_ARG_ENABLE(ppro, -[ --disable-ppro Disable PentiumPro optimizations (default enabled for x86)], + [ --disable-ppro Disable PentiumPro optimizations (default enabled for x86)], [ if test x$enableval = xyes; then ARCH="${ARCH} ppro"; fi ], [ if test x${host_cpu} = xi686; then ARCH="${ARCH} ppro"; fi ]) @@ -165,32 +245,25 @@ dnl AC_ARG_ENABLE(mmx, [ --disable-mmx Disable MMX optimizations (default enabled for x86)], [ if test x$enableval = xyes; then ARCH="${ARCH} mmx"; - BUILTINS="${BUILTINS} ${ACCEL_PLUGINS}"; fi ], -[ if test x${host_cpu} = xi686 -o x${host_cpu} = xi586 -o x${host_cpu} = xx86; then ARCH="${ARCH} mmx"; - BUILTINS="${BUILTINS} ${ACCEL_PLUGINS}"; fi ]) + BUILTINS="${BUILTINS} ${ACCEL_MODULES}"; fi ], +[ if test x${host_cpu} = xi686 -o x${host_cpu} = xi586 -o x${host_cpu} = xx86 -o x${host_cpu} = xi386; then ARCH="${ARCH} mmx"; + BUILTINS="${BUILTINS} ${ACCEL_MODULES}"; fi ]) dnl dnl AltiVec acceleration dnl AC_ARG_ENABLE(altivec, [ --enable-altivec Enable altivec optimizations (default disabled since it is broken)], -[ if test x$enableval = xyes; then ARCH="${ARCH} altivec"; +[ if test x$enableval = xyes; then ARCH="${ARCH} altivec" BUILTINS="${BUILTINS} idctaltivec" LIB_IDCTALTIVEC="-framework vecLib" fi ]) #[ if test -d /System/Library/Frameworks/vecLib.framework; then ARCH="${ARCH} altivec"; PLUGINS="${PLUGINS} idctaltivec"; fi ]) -dnl -dnl CSS DVD decryption -dnl -AC_ARG_ENABLE(css, -[ --disable-css Disable DVD CSS decryption (default enabled)], -[ if test x$enableval = xyes; then CSS=1; else CSS=0; fi ], [ CSS=1; ]) -if test x${CSS} = x1; then AC_DEFINE(HAVE_CSS, 1, Define if you want DVD CSS decryption.) fi - dnl dnl Debugging mode dnl +DEBUG=0 AC_ARG_ENABLE(debug, [ --enable-debug Enable debug mode (default disabled)], [ if test x$enableval = xyes; then DEBUG=1; fi ]) @@ -198,10 +271,27 @@ AC_ARG_ENABLE(debug, dnl dnl Enable/disable statistics dnl +STATS=0 AC_ARG_ENABLE(stats, [ --enable-stats Enable printing of statistics (default disabled)], [ if test x$enableval = xyes; then STATS=1; fi ]) +dnl +dnl Trace mode +dnl +TRACE=0 +AC_ARG_ENABLE(trace, +[ --enable-trace Enable trace mode (default disabled)], +[ if test x$enableval = xyes; then TRACE=1; fi ]) + +dnl +dnl Trace mode +dnl +PROFILING=0 +AC_ARG_ENABLE(profiling, +[ --enable-profiling Enable gprof profiling (default disabled)], +[ if test x$enableval = xyes; then PROFILING=1; fi ]) + dnl dnl Enable/disable optimizations dnl @@ -210,12 +300,131 @@ AC_ARG_ENABLE(optimizations, [ if test x$enableval = xno; then OPTIMS=0; fi ], [ OPTIMS=1 ]) -SYS=${host_os} +dnl +dnl GNU portable threads +dnl +AC_ARG_ENABLE(pth, + [ --enable-pth Enable GNU Pth support (default disabled)], + [ if test x$enableval = xyes; then + AC_CHECK_LIB(pth,pth_init) + AC_EGREP_HEADER(pth_init,pth.h,[ + AC_DEFINE(PTH_INIT_IN_PTH_H, 1, + Define if defines pth_init) + THREAD_LIB="-lpth" + fi]) +]) + +LIB="${LIB} ${THREAD_LIB}" + +dnl +dnl DVD module: check for installed libdvdcss or local libdvdcss +dnl +LOCAL_LIBDVDCSS=0 +STATIC_LIBDVDCSS=0 +AC_ARG_WITH(dvdcss, + [ --with-dvdcss[=name] way to use libdvdcss, either local-static, local-shared or a path to another libdvdcss such as /usr/local (default local-static)], + [ case "x${withval}" in + xlocal-static|xyes) + # local libdvdcss, statically linked + if test x${CAN_BUILD_LIBDVDCSS} = x1 + then + LOCAL_LIBDVDCSS=1 + STATIC_LIBDVDCSS=1 + BUILTINS="${BUILTINS} dvd" + CFLAGS_DVD="${CFLAGS_DVD} -I../../extras/libdvdcss" + LIB_DVD="${LIB_DVD} lib/libdvdcss.a" + LIB_DVD_PLUGIN="${LIB_DVD_PLUGIN} ../../lib/libdvdcss.a" + fi + ;; + xlocal-shared) + # local libdvdcss, dynamically linked + if test x${CAN_BUILD_LIBDVDCSS} = x1 + then + LOCAL_LIBDVDCSS=1 + BUILTINS="${BUILTINS} dvd" + CFLAGS_DVD="${CFLAGS_DVD} -I../../extras/libdvdcss" + LIB_DVD="${LIB_DVD} -Llib -ldvdcss" + LIB_DVD_PLUGIN="${LIB_DVD_PLUGIN} -L../../lib -ldvdcss" + fi + ;; + *) + # existing libdvdcss + BUILTINS="${BUILTINS} dvd" + if test "x$withval" != "xyes" + then + LIB_DVD_PLUGIN="${LIB_DVD_PLUGIN} -L"$withval"/lib" + CFLAGS_DVD="${CFLAGS_DVD} -I"$withval"/include" + fi + LIB_DVD="${LIB_DVD} -ldvdcss" + LIB_DVD_PLUGIN="${LIB_DVD_PLUGIN} -ldvdcss" + esac ], + # user didn't decide, we choose to use local libdvdcss and link statically + [ if test x${CAN_BUILD_LIBDVDCSS} = x1 + then + LOCAL_LIBDVDCSS=1 + STATIC_LIBDVDCSS=1 + BUILTINS="${BUILTINS} dvd" + CFLAGS_DVD="${CFLAGS_DVD} -I../../extras/libdvdcss" + LIB_DVD="${LIB_DVD} lib/libdvdcss.a" + LIB_DVD_PLUGIN="${LIB_DVD_PLUGIN} ../../lib/libdvdcss.a" + fi ]) + +dnl +dnl CSS DVD decryption (for libdvdcss) +dnl +CSS=0 +AC_ARG_ENABLE(css, + [ --disable-css Disable DVD CSS decryption (default enabled)], + [ if test x$enableval = xyes + then + CSS=1 + fi ], + [ CSS=1; ]) + +if test x${CSS} = x1 +then + AC_DEFINE(HAVE_CSS, 1, Define if you want DVD CSS decryption.) +fi + +dnl +dnl dummy plugin +dnl +AC_ARG_ENABLE(dummy, + [ --disable-dummy dummy module (default enabled)]) + +if test x$enable_dummy != xno +then + BUILTINS="${BUILTINS} dummy" +fi + +dnl +dnl null plugin +dnl +AC_ARG_ENABLE(null, + [ --disable-null Null module (default enabled)]) + +if test x$enable_null != xno +then + BUILTINS="${BUILTINS} null" +fi + +dnl +dnl rc plugin +dnl +AC_ARG_ENABLE(rc, + [ --disable-rc rc module (default enabled)]) + +if test x$enable_rc != xno +then + BUILTINS="${BUILTINS} rc" +fi dnl special case for BeOS -if test x$host_os = xbeos; then +if test x$SYS = xbeos +then BUILTINS="${BUILTINS} beos" LIB_BEOS="-lbe -lgame -lroot -ltracker" + PLCFLAGS="${PLCFLAGS} -nostart" dnl default case else @@ -225,8 +434,11 @@ dnl OSS /dev/dsp module dnl AC_ARG_ENABLE(dsp, [ --disable-dsp Linux /dev/dsp support (default enabled)]) -if test x$enable_dsp != xno; then - if test -c /dev/dsp; then + +if test x$enable_dsp != xno +then + if test -c /dev/dsp + then PLUGINS="${PLUGINS} dsp" fi fi @@ -236,9 +448,11 @@ dnl Esound module dnl AC_ARG_ENABLE(esd, [ --enable-esd Esound library support (default disabled)], - [if test x$enable_esd = xyes; then + [if test x$enable_esd = xyes + then AC_PATH_PROG(ESD_CONFIG, esd-config, no) - if test x${ESD_CONFIG} != xno; then + if test x${ESD_CONFIG} != xno + then PLUGINS="${PLUGINS} esd" LIB_ESD="`${ESD_CONFIG} --libs`" fi @@ -259,7 +473,8 @@ dnl MacOS X module dnl AC_ARG_ENABLE(macosx, [ --enable-macosx Mac OS X interface support (default enabled in Mac OS X)], - [if test x$enable_macosx = xyes; then + [if test x$enable_macosx = xyes + then BUILTINS="${BUILTINS} macosx" LIB_MACOSX="-framework CoreAudio -framework Carbon -framework AGL" LIB_TS="${LIB_TS} -framework AGL -framework Carbon" @@ -272,6 +487,19 @@ AC_ARG_ENABLE(macosx, LIB_SDL="${LIB_SDL} -framework AGL -framework Carbon" )]) +dnl +dnl QNX RTOS module +dnl +AC_ARG_ENABLE(qnx, + [ --disable-qnx QNX RTOS support (default enabled in QNX RTOS)]) + if test x$enable_qnx != xno + then + AC_CHECK_HEADERS(Ph.h, [ + PLUGINS="${PLUGINS} qnx" + LIB_QNX="-lasound -lph" + ]) + fi + dnl dnl Linux framebuffer module dnl @@ -284,10 +512,10 @@ dnl GGI module dnl AC_ARG_WITH(ggi, [ --with-ggi[=name] GGI support (default disabled)], - [ if test "x$withval" != "xno"; + [ if test "x$withval" != "xno" then - PLUGINS="${PLUGINS} ggi"; - if test "x$withval" != "xyes"; + PLUGINS="${PLUGINS} ggi" + if test "x$withval" != "xyes" then LIB_GGI="-l"$withval else @@ -298,25 +526,66 @@ AC_ARG_WITH(ggi, dnl dnl SDL module dnl -AC_ARG_WITH(sdl, - [ --with-sdl[=name] SDL support (default enabled)], - [ if test "x$withval" != "xno"; +AC_ARG_ENABLE(sdl, + [ --disable-sdl SDL support (default enabled)]) +if test "x$withval" != "xno" +then + AC_DEFINE(HAVE_SDL_SDL_H, 0, Define if you have SDL/SDL.h) + AC_DEFINE(HAVE_SDL11_SDL_H, 0, Define if you have SDL/SDL11.h) + AC_DEFINE(HAVE_SDL12_SDL_H, 0, Define if you have SDL/SDL12.h) + AC_PATH_PROG(SDL_CONFIG, sdl-config, no) + SDL_HEADER="SDL/SDL.h" + if test x${SDL_CONFIG} = xno; then + AC_PATH_PROG(SDL_CONFIG, sdl11-config, no) + SDL_HEADER="SDL11/SDL.h" + fi + if test x${SDL_CONFIG} = xno; then + AC_PATH_PROG(SDL_CONFIG, sdl12-config, no) + SDL_HEADER="SDL12/SDL.h" + fi + if test x${SDL_CONFIG} != xno; then + AC_CHECK_HEADERS($SDL_HEADER, [], + [ echo "The development package for SDL is not installed. Please install it" + echo "and try again." + exit ]) + if expr 1.1.5 \> $($SDL_CONFIG --version) >/dev/null then - PLUGINS="${PLUGINS} sdl"; - if test "x$withval" != "xyes"; + echo "You need SDL version 1.1.5 or later." + exit + fi + PLUGINS="${PLUGINS} sdl" + CFLAGS_SDL="`${SDL_CONFIG} --cflags`" + LIB_SDL="`${SDL_CONFIG} --libs | sed 's,-rdynamic,,'`" + elif test "x$withval" = "xyes" + then + echo "I couldn't find the SDL package. You can download libSDL from" + echo "http://www.libsdl.org/." + exit + fi +fi + +dnl +dnl Windows DirectX module +dnl +AC_ARG_WITH(directx, + [ --with-directx[=name] Windows DirectX support (default enabled)], + [ if test "x$withval" != "xno" + then + PLUGINS="${PLUGINS} directx" + if test "x$withval" != "xyes" then - LIB_SDL="${LIB_SDL} -L/usr/X11R6/lib -L"$withval"/lib -l"$withval + LIB_DIRECTX="${LIB_DIRECTX} -L"$withval"/lib -lgdi32 -ldxguid" INCLUDE="${INCLUDE} -I"$withval"/include" else - AC_CHECK_HEADERS(SDL/SDL.h, , [echo "Cannot find SDL headers !"; exit]) - LIB_SDL="${LIB_SDL} -L/usr/X11R6/lib -lSDL" + AC_CHECK_HEADERS(directx.h, , [echo "Cannot find DirectX headers !"; exit]) + LIB_DIRECTX="${LIB_DIRECTX} -L/usr/lib -lgdi32 -ldxguid" fi fi ]) - if test "x$withval" = "x"; + if test "x$withval" = "x" then - AC_CHECK_HEADERS(SDL/SDL.h, - [PLUGINS="${PLUGINS} sdl" - LIB_SDL="${LIB_SDL} -L/usr/X11R6/lib -lSDL"]) + AC_CHECK_HEADERS(directx.h, + [PLUGINS="${PLUGINS} directx" + LIB_DIRECTX="${LIB_DIRECTX} -L/usr/lib -lgdi32 -ldxguid"]) fi dnl @@ -324,14 +593,14 @@ dnl Glide module dnl AC_ARG_WITH(glide, [ --with-glide[=name] Glide (3dfx) support (default disabled)], - [ if test "x$withval" != "xno"; + [ if test "x$withval" != "xno" then - PLUGINS="${PLUGINS} glide"; - if test "x$withval" != "xyes"; + PLUGINS="${PLUGINS} glide" + if test "x$withval" != "xyes" then - LIB_GLIDE="-l"$withval + LIB_GLIDE="-l"$withval" -lm" else - LIB_GLIDE="-lglide2x" + LIB_GLIDE="-lglide2x -lm" fi fi ]) @@ -354,6 +623,12 @@ AC_ARG_ENABLE(qt, PLUGINS="${PLUGINS} qt" ALIASES="${ALIASES} qvlc" LIB_QT="-lqt -L${QTDIR}/lib" + if test -x ${QTDIR}/bin/moc + then + MOC=${QTDIR}/bin/moc + else + MOC=moc + fi fi]) dnl @@ -361,7 +636,11 @@ dnl KDE module dnl AC_ARG_ENABLE(kde, [ --enable-kde KDE interface support (default disabled)], - [if test x$enable_kde = xyes; then PLUGINS="${PLUGINS} kde"; ALIASES="${ALIASES} kvlc"; fi]) + [if test x$enable_kde = xyes; then + PLUGINS="${PLUGINS} kde" + ALIASES="${ALIASES} kvlc" + LIB_KDE="-lkfile" + fi]) dnl dnl Gnome module @@ -438,10 +717,15 @@ dnl ALSA module dnl AC_ARG_ENABLE(alsa, [ --enable-alsa Alsa sound drivers support (Only for linux) (default disabled)], - [if test x$enable_alsa = xyes; then AC_CHECK_HEADER(sys/asoundlib.h, AC_CHECK_LIB(asound, main, have_alsa="true", have_alsa="false"),have_alsa="false") if test x$have_alsa = xtrue; then - PLUGINS="${PLUGINS} alsa" - LIB_ALSA="-lasound" - fi; fi]) + [if test x$enable_alsa = xyes + then + AC_CHECK_HEADER(sys/asoundlib.h, AC_CHECK_LIB(asound, main, have_alsa="true", have_alsa="false"),have_alsa="false") + if test x$have_alsa = xtrue + then + PLUGINS="${PLUGINS} alsa" + LIB_ALSA="-lasound" + fi + fi]) dnl end of non-BeOS stuff fi @@ -458,49 +742,82 @@ AC_SUBST(DEFINE) AC_SUBST(INCLUDE) AC_SUBST(DEBUG) AC_SUBST(STATS) +AC_SUBST(ASM) +AC_SUBST(TRACE) +AC_SUBST(PROFILING) AC_SUBST(OPTIMS) +AC_SUBST(GETOPT) AC_SUBST(CSS) +AC_SUBST(MOC) +AC_SUBST(WINDRES) AC_SUBST(LCFLAGS) +AC_SUBST(PLCFLAGS) AC_SUBST(LIB) AC_SUBST(LIB_ALSA) AC_SUBST(LIB_BEOS) AC_SUBST(LIB_DARWIN) +AC_SUBST(LIB_DVD) +AC_SUBST(LIB_DVD_PLUGIN) AC_SUBST(LIB_ESD) AC_SUBST(LIB_GGI) AC_SUBST(LIB_GLIDE) AC_SUBST(LIB_GNOME) AC_SUBST(LIB_GTK) AC_SUBST(LIB_IDCTALTIVEC) +AC_SUBST(LIB_KDE) AC_SUBST(LIB_MACOSX) +AC_SUBST(LIB_QNX) AC_SUBST(LIB_NCURSES) AC_SUBST(LIB_QT) AC_SUBST(LIB_TS) AC_SUBST(LIB_SDL) +AC_SUBST(LIB_DIRECTX) AC_SUBST(LIB_X11) AC_SUBST(LIB_XVIDEO) AC_SUBST(LIB_YUV) +AC_SUBST(CFLAGS_VLC) +AC_SUBST(CFLAGS_DVD) AC_SUBST(CFLAGS_GTK) +AC_SUBST(CFLAGS_SDL) AC_SUBST(CFLAGS_X11) +AC_SUBST(LOCAL_LIBDVDCSS) + AC_OUTPUT([Makefile.opts include/config.h]) echo " +global configuration +-------------------- +system : ${SYS} +architecture : ${ARCH} +optimizations : ${OPTIMS} + vlc configuration ----------------- vlc version : ${VLC_VERSION} -system : ${SYS} -architecture : ${ARCH} debug mode : ${DEBUG} statistics : ${STATS} -optimizations : ${OPTIMS} -CSS decryption : ${CSS} +trace mode : ${TRACE} +profiling : ${PROFILING} need builtin getopt : ${GETOPT} -plugin modules : ${PLUGINS} -built-in modules : ${BUILTINS} -vlc aliases : ${ALIASES} +built-in modules :${BUILTINS} +plugin modules :${PLUGINS} +vlc aliases :${ALIASES} + +libdvdcss configuration +----------------------- +need to be built : ${LOCAL_LIBDVDCSS}" + +if test x${LOCAL_LIBDVDCSS} = x1 +then + echo "link statically : ${STATIC_LIBDVDCSS} +CSS decryption : ${CSS}" +fi -You may now tune Makefile.opts at your convenience." +echo " +You may now tune Makefile.opts at your convenience. To build vlc, type +\`make vlc'. To build libdvdcss only, type \`make libdvdcss'."