]> git.sesse.net Git - vlc/blobdiff - extras/contrib/src/Makefile
Fix libgcrypt compil under cygwin. It doesn't have gettimeoftheday() and it's wongly...
[vlc] / extras / contrib / src / Makefile
index 39a289c314fb952d9e41b7ae2ff80763b3f9989c..97a762c9166827519d9b2e683d14b54a939fefe6 100644 (file)
@@ -1,4 +1,4 @@
-# ***************************************************************************
+#***************************************************************************
 # src/Makefile : Dearchive and compile all files necessary
 # ***************************************************************************
 # Copyright (C) 2003 - 2006 the VideoLAN team
@@ -8,8 +8,9 @@
 #          Derk-Jan Hartman <hartman at videolan dot org>
 #          Eric Petit <titer@m0k.org>
 #          Felix Kühne <fkuehne@users.sourceforge.net>
-#          Christophe Mutricy <xtophe@nxtelevision.com>
+#          Christophe Mutricy <xtophe AT xtelevision.com>
 #          Gildas Bazin <gbazin at videolan dot org>
+#          Damien Fouilleul <damienf at videolan dot org>
 #
 # This program is free software; you can redistribute it and/or modify
 # it under the terms of the GNU General Public License as published by
@@ -35,7 +36,11 @@ include ./packages.mak
 
 export PATH := $(PREFIX)/bin:$(EXTRA_PATH):$(PATH)
 export PKG_CONFIG_PATH
+export PKG_CONFIG_LIBDIR = $(PREFIX)/lib/pkgconfig
 export DYLD_LIBRARY_PATH = $(PREFIX)/lib
+# following is required for configure scripts that check dyld libraries
+# by building and running a test app 
+export DYLD_LIBRARY_PATH := $(DYLD_LIBRARY_PATH):$(PREFIX)/vlc-lib
 export MACOSX_DEPLOYMENT_TARGET = $(SDK_TARGET)
 export LIBRARY_PATH := $(PREFIX)/lib:$(LIBRARY_PATH)
 export CFLAGS = -I$(PREFIX)/include $(EXTRA_CFLAGS) $(EXTRA_CPPFLAGS)
@@ -78,22 +83,32 @@ else
 HOSTCC2=$(HOSTCC)
 endif
 
+# For ffmpeg if not cross compiling
+ifneq ($(CC),)
+  FFMPEGCONF=--cc="$(CC)"
+endif
+
+#
+# cross compiling
+#
 ifneq ($(BUILD),$(HOST))
-# We are cross compiling
-HOSTCONF=--host=$(HOST) --build=$(BUILD)
-FFMPEGCONF=--cross-prefix=$(HOST)-
-X264CONF=--crosscompile=$(HOST)
-else
-   ifneq ($(CC),)
-      FFMPEGCONF=--cc="$(CC)"
-   endif
+    #
+    # Compiling for MinGW under Cygwin could be deemed as cross compiling
+    # unfortunately there isn't a complete separate GCC toolchain for MinGW under Cygwin
+    #
+    HOSTCONF=--host=$(HOST) --build=$(BUILD)
+    ifeq ($(findstring cygwin,$(BUILD)),)
+       # We are REALLY cross compiling
+       FFMPEGCONF=--cross-prefix=$(HOST)-
+       X264CONF=--crosscompile=$(HOST)
+    endif
 endif
 
 #
 # Special target-dependant options
 #
 ifdef HAVE_WIN32
-HOSTCONF+= --without-pic --disable-shared --enable-msw --with-included-opencdk --with-included-libtasn1 --disable-depedency-tracking
+HOSTCONF+= --without-pic --disable-shared --enable-msw --with-included-opencdk --with-included-libtasn1 --disable-dependency-tracking
 FFMPEGCONF+= --enable-mingw32 --enable-memalign-hack --cpu=x86 --disable-debug
 endif
 
@@ -105,13 +120,20 @@ FFMPEGCONF+= --enable-mp3lame --enable-faac
 endif
 
 ifdef HAVE_BEOS
-FFMPEGCONF+= --cpu=x86
+FFMPEGCONF+= --cpu=x86 --disable-debug --disable-audio-beos
 endif
 
 ifeq ($(HOST),i686-apple-darwin8)
 FFMPEGCONF += --enable-memalign-hack
 endif
 
+ifdef HAVE_DARWIN_OS
+X264CONF += --enable-pic --enable-debug
+ifneq ($(HOST),i686-apple-darwin8)
+FFMPEG_CFLAGS += -DHAVE_LRINTF
+endif
+endif
+
 # ***************************************************************************
 # Standard rules
 # ***************************************************************************
@@ -120,15 +142,13 @@ ifdef HAVE_DARWIN_OS
  all: .autoconf .automake .libtool .intl .pkgcfg .freetype .fribidi \
        .a52 .mpeg2 .id3tag .mad .ogg .vorbis .vorbisenc .theora \
        .FLAC .speex .shout .faad .faac .lame .twolame .ebml .matroska .ffmpeg \
-       .dvdcss .dvdnav .dvdread .dvbpsi .live .x264 .caca .mod \
+       .dvdcss .dvdnav .dvdread .dvbpsi .live .caca .mod \
        .png .gpg-error .gcrypt .gnutls .opendaap .cddb .cdio .vcdimager .SDL_image \
-       .glib .libidl .gecko .mpcdec .expat .clinkcc .aclocal
-# .FLAC .expat .clinkcc don't work with SDK yet
+       .glib .libidl .gecko .mpcdec .dirac_encoder .dirac_decoder .aclocal \
+        .libdca .tag .x264 .goom2k4
+# .expat .clinkcc don't work with SDK yet
 # .glib .libidl .gecko are required to build the mozilla plugin
 # .mozilla will build an entire mozilla. it can be used if we need to create a new .gecko package
-ifneq ($(HOST),i686-apple-darwin8)
-all: .goom2k4
-endif
 else
 
  ifdef HAVE_BEOS
@@ -137,42 +157,44 @@ else
    all: .perl .autoconf .automake .libtool .iconv .intl .freetype .fribidi \
        .a52 .mpeg2 .id3tag .mad .ogg .vorbis .vorbisenc .theora \
        .FLAC .speex .faad .faac .lame .ebml .matroska .ffmpeg .dvdcss \
-       .dvdnav .dvbpsi .aclocal
+       .dvdnav .dvbpsi .aclocal .libdca
   else
 # Cross compiling: we already have the Linux tools, only build the
 # libraries now
    all: .iconv .intl .freetype .fribidi \
        .a52 .mpeg2 .id3tag .mad .ogg .vorbis .vorbisenc .theora \
        .FLAC .speex .faad .faac .lame .twolame .ebml .matroska .ffmpeg .dvdcss \
-       .dvdnav .dvbpsi .aclocal
+       .dvdnav .dvbpsi .aclocal .libdca
   endif
  else
 
   ifdef HAVE_WIN32
 
    all: .iconv .intl .freetype .fribidi .zlib \
-       .a52 .mpeg2 .id3tag .mad .ogg .vorbis .vorbisenc .theora \
+       .a52 .mpeg2 .id3tag .mad .ogg .vorbis .shout .vorbisenc .theora \
        .FLAC .speex .faad .faac .lame .ebml  .matroska .ffmpeg .dvdcss \
        .live .goom2k4 .caca .mod .x264  .xml .twolame \
        .png .gpg-error .gcrypt .gnutls .mpcdec \
-       .gnutls .dvdnav .dvbpsi .wxwidgets .dirac \
-       .dx_headers .dshow_headers .aclocal .gecko-win32
-#      .SDL_image  .daap .cddb .cdio .vcdimager .dts .portaudio 
+       .dvdnav .dvbpsi .wxwidgets .qt4 .dirac \
+       .dx_headers .dshow_headers .aclocal .gecko-win32 .unicows .libdca \
+       .SDL_image
+#      .SDL_image  .daap .cddb .cdio .vcdimager .portaudio 
   else
 
    ifdef HAVE_WINCE
 
    all: .dvbpsi .zlib .ffmpeg .ogg .tremor .faad
-   else
 
+   else
 # Standard Linux or other UNIX-like systems
    all: .iconv .intl .freetype .fribidi .zlib \
        .a52 .mpeg2 .id3tag .mad .ogg .vorbis .vorbisenc .theora \
-       .FLAC .speex .faad .faac .lame .ebml .dts .matroska .ffmpeg .dvdcss \
+       .FLAC .speex .faad .faac .lame .ebml .matroska .ffmpeg .dvdcss \
        .live .goom2k4 .caca .mod .x264  .xml .twolame\
        .png .gpg-error .gcrypt .gnutls .mpcdec\
-       .gnutls .dvdnav .dvbpsi .wxwidgets .dirac \
-       .aclocal 
+       .dvdnav .dvbpsi .wxwidgets .dirac \
+       .aclocal .libdca
+#      .png .gpg-error .gcrypt .gnutls .mpcdec\
 #      .SDL_image  .daap .cddb .cdio .vcdimager 
    endif
   endif
@@ -186,17 +208,26 @@ FORCE:
 # ***************************************************************************
 
 define EXTRACT_GZ
-       tar xzf $<
+       rm -rf $@ || true
+       tar xzf $< --exclude='[*?:<>\|]' 
        mv $(patsubst %.tar.gz,%,$(patsubst %.tgz,%,$(notdir $<))) $@ || true
        touch $@
 endef
 
 define EXTRACT_BZ2
-       bunzip2 -c $< | tar xf -
+       rm -rf $@ || true
+       bunzip2 -c $< | tar xf - --exclude='[*?:<>\|]' 
        mv $(patsubst %.tar.bz2,%,$(notdir $<)) $@ || true
        touch $@
 endef
 
+define EXTRACT_ZIP
+       rm -rf $@ || true
+       unzip $<
+       mv $(patsubst %.zip,%,$(notdir $<)) $@ || true
+       touch $@
+endef
+
 ### Darwin-specific ###
 # These macros prepare the dynamic libraries for inclusion in the Mac OS X
 # bundle. For instance if you're building a library named libtoto.dylib,
@@ -210,25 +241,35 @@ endef
 #      touch $@
 
 ifdef HAVE_DARWIN_OS
-define INSTALL_NAME_LIB
-       install_name_tool \
-               -change $(PREFIX)/lib/$(shell cd $(PREFIX)/lib; ls | grep "lib$(INSTALL_LIB).[0-9]*.dylib") \
-               @executable_path/lib/vlc_lib$(INSTALL_LIB).dylib \
-               $(PREFIX)/vlc-lib/lib$(patsubst .%,%,$@).dylib ;
-endef
+# the original libtoto.dylib is copied from contrib/lib to vlc-lib as
+# vlc_libtoto.dylib. a soft link to this library is created in contrib/lib
+# using the orginal dylib name. if libtoto.la also exists, the library named
+# in dlname is also changed to a soft-link to vlc-lib in order to support
+# libtool. to satisfy VLC.app dyld search, vlc_libtoto.dylib dyld id is changed
+# to @executable_path/lib/vlc_libtoto.dylib 
 
 define INSTALL_NAME
        if which install_name_tool >/dev/null; then \
                mkdir -p $(PREFIX)/vlc-lib ; \
-               cp $(PREFIX)/lib/lib$(patsubst .%,%,$@).dylib \
-                       $(PREFIX)/vlc-lib/lib$(patsubst .%,%,$@).dylib ; \
+               libname='lib$(patsubst .%,%,$@)' ; \
+               dlname="$$libname.dylib" ; \
+               cp $(PREFIX)/lib/$$dlname \
+                       $(PREFIX)/vlc-lib/vlc_$$dlname ; \
+               rm $(PREFIX)/lib/$$dlname ; \
+               ln -s $(PREFIX)/vlc-lib/vlc_$$dlname \
+                       $(PREFIX)/lib/$$dlname ; \
+               if [ -f $(PREFIX)/lib/$$libname.la ]; then \
+                       eval ltname=`sed -n 's/dlname=//p' $(PREFIX)/lib/$$libname.la`; \
+                       rm $(PREFIX)/lib/$$ltname ; \
+                       ln -s $(PREFIX)/vlc-lib/vlc_$$dlname \
+                               $(PREFIX)/lib/$$ltname ; \
+               fi ; \
                install_name_tool \
-                       -id @executable_path/lib/vlc_lib$(patsubst .%,%,$@).dylib \
-                       $(PREFIX)/vlc-lib/lib$(patsubst .%,%,$@).dylib ; \
-               $(foreach INSTALL_LIB,$(patsubst .%,%,$(filter .%,$^)), \
-                       $(INSTALL_NAME_LIB)) \
+                       -id @executable_path/lib/vlc_$$dlname \
+                       $(PREFIX)/vlc-lib/vlc_$$dlname ; \
        fi
 endef
+
 endif
 
 ifeq ($(HOST),i586-pc-beos)
@@ -268,11 +309,11 @@ endif
 # autoconf
 # ***************************************************************************
 
-autoconf-$(AUTOCONF_VERSION).tar.gz:
+autoconf-$(AUTOCONF_VERSION).tar.bz2:
        $(WGET) $(AUTOCONF_URL)
 
-autoconf: autoconf-$(AUTOCONF_VERSION).tar.gz
-       $(EXTRACT_GZ)
+autoconf: autoconf-$(AUTOCONF_VERSION).tar.bz2
+       $(EXTRACT_BZ2)
 
 .autoconf: autoconf
        (cd $<; ./configure --prefix=$(PREFIX) && make && make install)
@@ -280,7 +321,7 @@ autoconf: autoconf-$(AUTOCONF_VERSION).tar.gz
 
 CLEAN_FILE += .autoconf
 CLEAN_PKG += autoconf
-DISTCLEAN_PKG += autoconf-$(AUTOCONF_VERSION).tar.gz
+DISTCLEAN_PKG += autoconf-$(AUTOCONF_VERSION).tar.bz2
 
 # ***************************************************************************
 # libtool
@@ -362,6 +403,10 @@ gettext-$(GETTEXT_VERSION).tar.gz:
 
 gettext: gettext-$(GETTEXT_VERSION).tar.gz
        $(EXTRACT_GZ)
+ifdef HAVE_DARWIN_OS
+       patch -p 0 < Patches/gettext-macosx.patch
+       (cd $@; ./autogen.sh)
+endif
 
 .intl: gettext .iconv
 ifdef HAVE_WIN32
@@ -410,7 +455,7 @@ ifdef HAVE_DARWIN_OS
        touch $@
 else
 .iconv: libiconv
-       (cd libiconv; CPPFLAGS="-Dssize_t=long" $(HOSTCC) ./configure $(HOSTCONF) --prefix=$(PREFIX) --disable-nls && make && make install)
+       (cd libiconv; $(HOSTCC) ./configure $(HOSTCONF) --prefix=$(PREFIX) --disable-nls && make && make install)
        $(INSTALL_NAME)
        touch $@
 endif
@@ -488,17 +533,16 @@ DISTCLEAN_PKG += a52dec-$(A52DEC_VERSION).tar.gz
 #      cvs -d $(MPEG2DEC_CVSROOT) co mpeg2dec
 #      (cd $@; ./bootstrap)
 
-#mpeg2dec-$(MPEG2DEC_VERSION).tar.gz:
-#      $(WGET) $(MPEG2DEC_URL)
+mpeg2dec-$(MPEG2DEC_VERSION).tar.gz:
+       $(WGET) $(MPEG2DEC_URL)
 
 # It is easier to use bootstrapped versions...
-mpeg2dec-$(MPEG2DEC_VERSION).tar.gz:
-       $(WGET) $(MPEG2DEC_SNAPSHOT)
-       mv mpeg2dec-$(MPEG2DEC_DATE).tar.gz $@
+#mpeg2dec-$(MPEG2DEC_VERSION).tar.gz:
+#      $(WGET) $(MPEG2DEC_SNAPSHOT)
+#      mv mpeg2dec-$(MPEG2DEC_DATE).tar.gz $@
 
 mpeg2dec: mpeg2dec-$(MPEG2DEC_VERSION).tar.gz
        $(EXTRACT_GZ)
-       patch -p 0 < Patches/mpeg2dec.patch
 
 .mpeg2: mpeg2dec
        (cd $<; $(HOSTCC) ./configure $(HOSTCONF) --prefix=$(PREFIX) --without-x --disable-sdl && cd libmpeg2 && make && make install && cd ../include && make && make install)
@@ -648,10 +692,16 @@ libtheora-$(THEORA_VERSION).tar.bz2:
 libtheora: libtheora-$(THEORA_VERSION).tar.bz2
        $(EXTRACT_BZ2)
        patch -p0 < Patches/theora.patch
+       patch -p0 < Patches/theora-1.0a7.patch
        (cd $@; autoconf)
 
 .theora: libtheora .ogg
+ifdef HAVE_BEOS
+       (cd $<; $(HOSTCC) ./configure $(HOSTCONF) --prefix=$(PREFIX) --disable-sdltest --disable-oggtest --disable-vorbistest --disable-asm && make && make install)
+else
        (cd $<; $(HOSTCC) ./configure $(HOSTCONF) --prefix=$(PREFIX) --disable-sdltest --disable-oggtest --disable-vorbistest && make && make install)
+
+endif
        $(INSTALL_NAME)
        touch $@
 
@@ -668,9 +718,13 @@ libshout-$(SHOUT_VERSION).tar.gz:
 
 libshout: libshout-$(SHOUT_VERSION).tar.gz
        $(EXTRACT_GZ)
-
-.shout: libshout .theora .ogg
-       (cd $<; $(HOSTCC) ./configure $(HOSTCONF) --prefix=$(PREFIX) && make && make install)
+ifdef HAVE_WIN32
+       patch -p0 < Patches/libshout-win32.patch
+       (cd $@; aclocal && automake)
+endif
+  
+.shout: libshout .theora .ogg .speex
+       (cd $<; $(HOSTCC) ./configure $(HOSTCONF) --prefix=$(PREFIX) &&  make && make install )
        $(INSTALL_NAME)
        touch $@
 
@@ -698,7 +752,11 @@ endif
 ifdef HAVE_WIN32
        (cd $<; $(HOSTCC) ./configure $(HOSTCONF) --prefix=$(PREFIX) --disable-oggtest --disable-asm-optimizations && cd src&& make -C libFLAC&& make -C libFLAC install  && cd .. && make -C include install)
 else
-       (cd $<; autoconf && $(HOSTCC) ./configure $(HOSTCONF) --prefix=$(PREFIX) --disable-oggtest && cd src&& make -C libFLAC&& make -C libFLAC install  && cd .. && make -C include install)
+ifdef HAVE_DARWIN_OS
+       (cd $<; autoconf && $(HOSTCC) ./configure $(HOSTCONF) --prefix=$(PREFIX) --disable-oggtest && sed -e 's%-Wl,-syslibroot,%-syslibroot %' -i.orig src/libFLAC/Makefile && cd src && make -C libFLAC && make -C libFLAC install  && cd .. && make -C include install)
+else
+       (cd $<; autoconf && $(HOSTCC) ./configure $(HOSTCONF) --prefix=$(PREFIX) --disable-oggtest && cd src && make -C libFLAC && make -C libFLAC install  && cd .. && make -C include install)
+endif
 endif
        $(INSTALL_NAME)
        touch $@
@@ -717,6 +775,9 @@ speex-$(SPEEX_VERSION).tar.gz:
 speex: speex-$(SPEEX_VERSION).tar.gz
        $(EXTRACT_GZ)
        patch -p0 < Patches/speex.patch
+ifdef HAVE_BEOS
+       patch -p0 < Patches/speex-BeOS.patch
+endif
 
 .speex: speex
        (cd $<; $(HOSTCC) ./configure $(HOSTCONF) --prefix=$(PREFIX) --enable-ogg=no && make && make install)
@@ -741,19 +802,17 @@ DISTCLEAN_PKG += speex-$(SPEEX_VERSION).tar.gz
 faad2-$(FAAD2_VERSION).tar.bz2:
        $(WGET) $(FAAD2_URL)
 
-faad2: faad2-$(FAAD2_VERSION).tar.bz2
+faad: faad2-$(FAAD2_VERSION).tar.bz2
        $(EXTRACT_BZ2)
        (cd $@; patch -p 0  < ../Patches/faad2.patch && ./bootstrap)
 
-.faad: faad2
-       (cd $< && $(HOSTCC) ./configure $(HOSTCONF) --prefix=$(PREFIX) CFLAGS="-O3" && make -C libfaad && make -C libfaad install)
-ifndef HAVE_DARWIN_OS
+.faad: faad
+       (cd $< && $(HOSTCC) ./configure $(HOSTCONF) --prefix=$(PREFIX) CFLAGS="-O3" && sed -i.orig "s/shrext_cmds/shrext/g" libtool && make -C libfaad && make -C libfaad install)
        $(INSTALL_NAME)
-endif
        touch $@
 
 CLEAN_FILE += .faad
-CLEAN_PKG += faad2
+CLEAN_PKG += faad
 DISTCLEAN_PKG += faad2-$(FAAD2_VERSION).tar.bz2
 
 # ***************************************************************************
@@ -784,6 +843,7 @@ lame-$(LAME_VERSION).tar.gz:
 
 lame: lame-$(LAME_VERSION).tar.gz
        $(EXTRACT_GZ)
+       rm -rf lame;  mv lame-3.97 lame; touch lame
 
 .lame: lame
        (cd $<; $(HOSTCC) ./configure $(HOSTCONF) --prefix=$(PREFIX) --disable-analyser-hooks --disable-decoder --disable-shared --disable-gtktest --disable-frontend && make && make install)
@@ -860,19 +920,12 @@ DISTCLEAN_PKG += libmatroska-$(LIBMATROSKA_VERSION).tar.bz2
 # ***************************************************************************
 
 ffmpeg:
-       echo $(FFMPEG_CVSROOT) A > ./ffmpeg.cvs
-       CVS_PASSFILE=./ffmpeg.cvs cvs -z3 -d $(FFMPEG_CVSROOT) co ffmpeg
+       $(SVN) co $(FFMPEG_SVN)  ffmpeg
 ifeq ($(HOST),i586-pc-beos)
-       (cd $@; patch -p 0 < ../Patches/ffmpeg-cvs-beos.patch)
-endif
-ifdef HAVE_WIN32
-       patch -p 0 < Patches/ffmpeg-cvs-win32.patch
+       (cd $@; patch -p 0 < ../Patches/ffmpeg-svn-beos.patch)
 endif
 ifdef HAVE_WINCE
-       patch -p 1 < Patches/ffmpeg-cvs-wince.patch
-endif
-ifeq ($(HOST),i686-apple-darwin8)
-       (cd $@;patch -p 0 < ../Patches/ffmpeg-cvs-mactel.patch)
+       patch -p 1 < Patches/ffmpeg-svn-wince.patch
 endif
 
 ffmpeg-$(FFMPEG_VERSION).tar.gz:
@@ -887,7 +940,7 @@ ifdef HAVE_WINCE
 else
 .ffmpeg: ffmpeg .faac .lame
 endif
-       (cd $<; $(HOSTCC) ./configure $(FFMPEGCONF) --prefix=$(PREFIX) --extra-cflags="$(CFLAGS) -DRUNTIME_CPUDETECT" --extra-ldflags="$(LDFLAGS)" --enable-gpl --enable-pp --disable-vhook --disable-ffserver --disable-network --enable-a52 --disable-ffplay && make install-libs install-headers)
+       (cd $<; $(HOSTCC) ./configure $(FFMPEGCONF) --prefix=$(PREFIX) --extra-cflags="$(CFLAGS) $(FFMPEG_CFLAGS) -DRUNTIME_CPUDETECT" --extra-ldflags="$(LDFLAGS)" --enable-gpl --enable-pp --disable-vhook --disable-ffserver --disable-network --enable-a52 --disable-ffplay && make install-libs install-headers)
        touch $@
 
 CLEAN_FILE += .ffmpeg
@@ -911,7 +964,7 @@ libdvdcss: libdvdcss-$(LIBDVDCSS_VERSION).tar.gz
 endif
 
 .dvdcss: libdvdcss
-       (cd $<; $(HOSTCC) ./configure $(HOSTCONF) --prefix=$(PREFIX) && make && make install)
+       (cd $<; $(HOSTCC) ./configure $(HOSTCONF) --disable-doc --prefix=$(PREFIX) && make && make install)
        $(INSTALL_NAME)
        touch $@
 
@@ -952,7 +1005,7 @@ DISTCLEAN_PKG += libdvdcss-$(LIBDVDCSS_VERSION).tar.gz
 # ***************************************************************************
 .dvdread: .dvdnav
        $(INSTALL_NAME)
-       (install_name_tool -change $(PREFIX)/lib/libdvdread.0.dylib @executable_path/lib/vlc_libdvdread.dylib $(PREFIX)/vlc-lib/libdvdnav.dylib)
+       (install_name_tool -change $(PREFIX)/lib/libdvdread.0.dylib @executable_path/lib/vlc_libdvdread.dylib $(PREFIX)/vlc-lib/vlc_libdvdnav.dylib)
        touch $@
 
 CLEAN_FILE += .dvdread
@@ -1016,16 +1069,19 @@ live: live555-$(LIVEDOTCOM_VERSION).tar.gz
        patch -p 0 < Patches/live-osx.patch
 
 .live: live
-ifeq ($(HOST),powerpc-apple-darwin8)
-       (cd $<; sed -e 's%EXTRA_CFLAGS%$(EXTRA_CFLAGS)%' -e 's%EXTRA_LDFLAGS%$(EXTRA_LDFLAGS)%' -i.orig  config.macosx)
-       (cd $<; ./genMakefiles macosx && make)
+ifdef HAVE_WIN32 
+       (cd $<;./genMakefiles mingw && make $(HOSTCC))
 else
-ifeq ($(HOST),powerpc-apple-darwin*)
+ifeq ($(HOST),ppc-darwin)
        (cd $<; ./genMakefiles macosx-before-version-10.4 && make )
-elif defined( HAVE_WIN32 )
-       (cd $<;./genMakefiles mingw && make $(HOSTCC))
 else
-       (cd $<;./genMakefiles linux && make )
+ifdef HAVE_DARWIN_OS
+       (cd $<; sed -e 's%EXTRA_CFLAGS%$(EXTRA_CFLAGS)%' -e 's%EXTRA_LDFLAGS%$(EXTRA_LDFLAGS)%' -i.orig  config.macosx)
+       (cd $<; ./genMakefiles macosx && make)
+else
+       (cd $<; sed -e 's/=/= EXTRA_CPPFLAGS/' -e 's%EXTRA_CPPFLAGS%-I/include%' -i.orig groupsock/Makefile.head)
+       (cd $<; ./genMakefiles linux && make $(HOSTCC))
+endif
 endif
 endif
        touch $@
@@ -1067,7 +1123,9 @@ ifdef HAVE_DARWIN_OS
 endif
 ifdef HAVE_WIN32
        (cd $@; dos2unix configure.in)
-       patch -p 0 <Patches/goom2k4-0-win32.patch
+       patch -p 0 < Patches/goom2k4-0-win32.patch
+else
+       patch -p 0 < Patches/goom2k4-0-mmx.patch
 endif
 
 .goom2k4: goom
@@ -1105,29 +1163,19 @@ CLEAN_PKG += libcaca
 DISTCLEAN_PKG += libcaca-$(LIBCACA_VERSION).tar.gz
 
 # ***************************************************************************
-# libdts
+# libdca
 # ***************************************************************************
 
-libdts-$(LIBDTS_VERSION).tar.gz:
-       $(WGET) $(LIBDTS_URL)
-
-ifeq ($(HOST),i586-pc-beos)
-# libdts 0.0.2 doesn't compile on BeOS
-libdts:
-       $(SVN) co svn://svn.videolan.org/libdts/trunk libdts
+libdca:
+       $(SVN) co $(LIBDCA_SVN) libdca
        (cd $@; ./bootstrap)
-else
-libdts: libdts-$(LIBDTS_VERSION).tar.gz
-       $(EXTRACT_GZ)
-endif
 
-.dts: libdts
+.libdca: libdca
        (cd $<; $(HOSTCC) ./configure $(HOSTCONF) --prefix=$(PREFIX) && make && make install)
        touch $@
 
-CLEAN_FILE += .dts
-CLEAN_PKG += libdts
-DISTCLEAN_PKG += libdts-$(LIBDTS_VERSION).tar.gz
+CLEAN_FILE += .libdca
+CLEAN_PKG += libdca
 
 # ***************************************************************************
 # libx264
@@ -1138,9 +1186,6 @@ x264:
        $(SVN) co svn://svn.videolan.org/x264/trunk/ x264
 ifdef HAVE_WIN32
        (cd x264; patch -p 0 < ../Patches/x264-svn-win32.patch )
-else
-       patch -p 0 < Patches/x264_svn.patch
-       rm x264/x264.c
 endif
 else
 x264-$(X264_VERSION).tar.gz:
@@ -1239,7 +1284,7 @@ libcdio: libcdio-$(CDIO_VERSION).tar.gz
        $(EXTRACT_GZ)
 
 .cdio: libcdio
-       (cd $<; ./configure --prefix=$(PREFIX) --without-vcdinfo --disable-shared && make && make install)
+       (cd $<; sed -e 's%@ENABLE_CPP_TRUE@SUBDIRS = C++%@ENABLE_CPP_TRUE@SUBDIRS = %' -i.orig example/Makefile.in && ./configure --prefix=$(PREFIX) --without-vcdinfo --disable-shared && make && make install)
        touch $@
 
 CLEAN_FILE += .cdio
@@ -1273,6 +1318,7 @@ wxWidgets-$(WXWIDGETS_VERSION).tar.gz:
 
 wxwidgets: wxWidgets-$(WXWIDGETS_VERSION).tar.gz
        $(EXTRACT_GZ)
+       (cd wxwidgets; patch -p0 < ../Patches/wxwidgets_uri.patch)
 #      (cd wxwidgets; patch -p1 <../Patches/wxMSW-win32.patch)
 
 .wxwidgets: wxwidgets
@@ -1284,6 +1330,25 @@ CLEAN_FILE += .wxwidgets
 CLEAN_PKG += wxwidgets
 DISTCLEAN_PKG += wxWidgets-$(WXWIDGETS_VERSION).tar.gz
 
+# ***************************************************************************
+# qt4 (win32 binary)
+# ***************************************************************************
+
+qt4-$(QT4_VERSION)-win32-bin.tar.gz:
+       $(WGET) $(QT4_URL)
+
+qt4: qt4-$(QT4_VERSION)-win32-bin.tar.gz
+       $(EXTRACT_GZ)
+
+
+.qt4: qt4
+       (cd qt4;mkdir -p $(PREFIX)/bin; mkdir -p $(PREFIX)/include;mkdir -p $(PREFIX)/lib/pkgconfig;rm -f $(PREFIX)/lib/pkgconfig/Qt*; sed 's,@@PREFIX@@,$(PREFIX),' lib/pkgconfig/QtCore.pc.in > $(PREFIX)/lib/pkgconfig/QtCore.pc;sed 's,@@PREFIX@@,$(PREFIX),' lib/pkgconfig/QtGui.pc.in > $(PREFIX)/lib/pkgconfig/QtGui.pc;cp -r include/* $(PREFIX)/include;cp lib/*a $(PREFIX)/lib;cp bin/rcc bin/uic bin/moc $(PREFIX)/bin)
+       touch $@
+
+CLEAN_FILE += .qt4
+CLEAN_PKG += qt4
+DISTCLEAN_PKG += qt4-$(QT4_VERSION).tar.gz
+
 # ***************************************************************************
 # zlib
 # ***************************************************************************
@@ -1296,7 +1361,7 @@ zlib: zlib-$(ZLIB_VERSION).tar.gz
        patch -p 0 < Patches/zlib.patch
 
 .zlib: zlib
-       (cd zlib; $(HOSTCC2) ./configure  --prefix=$(PREFIX) && make install)
+       (cd zlib; $(HOSTCC2) ./configure --prefix=$(PREFIX) && make install)
        $(INSTALL_NAME)
        touch $@
 
@@ -1343,7 +1408,7 @@ ifdef HAVE_WIN32
 endif
 
 .xml: xml
-       (cd xml; $(HOSTCC) ./configure $(HOSTCONF) --prefix=$(PREFIX) --with-minimal --with-catalog --with-reader --with-tree --with-push --with-xptr --with-valid --with-writer --with-output --with-xpath --with-xinclude --with-sax1 --without-zlib --without-iconv --without-http --without-ftp && make && make install)
+       (cd xml; CFLAGS="-DLIBXML_STATIC" $(HOSTCC) ./configure $(HOSTCONF) --prefix=$(PREFIX) --with-minimal --with-catalog --with-reader --with-tree --with-push --with-xptr --with-valid --with-xpath --with-xinclude --with-sax1 --without-zlib --without-iconv --without-http --without-ftp && make && make install)
 ifndef HAVE_DARWIN_OS
        $(INSTALL_NAME)
 endif
@@ -1363,6 +1428,9 @@ twolame-$(TWOLAME_VERSION).tar.gz:
 
 twolame: twolame-$(TWOLAME_VERSION).tar.gz
        $(EXTRACT_GZ)
+ifdef HAVE_BEOS
+       patch -p 0 < Patches/twolame-BeOS.patch
+endif
 
 .twolame: twolame
        (cd twolame; $(HOSTCC) ./configure $(HOSTCONF) --prefix=$(PREFIX) && make && make install)
@@ -1383,19 +1451,27 @@ libpng-$(PNG_VERSION).tar.bz2:
 libpng: libpng-$(PNG_VERSION).tar.bz2
        $(EXTRACT_BZ2)
 ifdef HAVE_WIN32
-       (cd $@; cat ../Patches/libpng-1.2.5-win32.patch | sed s,??PREFIX??,$(PREFIX), | patch -p0)
+       (cd $@; cat ../Patches/libpng-win32.patch | sed s,??PREFIX??,$(PREFIX), | patch -p0)
 else
        (cat Patches/libpng-osx.patch | sed -e 's%??PREFIX??%$(PREFIX)%' -e 's%??EXTRA_CFLAGS??%$(EXTRA_CFLAGS)%' -e 's%??EXTRA_LDFLAGS??%$(EXTRA_LDFLAGS)%' | patch -p0)
 endif
+       (patch -p 0 < Patches/libpng-makefile.patch)
+ifeq ($(HOST),i686-apple-darwin8)
+       (patch -p 0 < Patches/libpng-darwin-mactel.patch)
+endif
 
 .png: libpng 
 ifdef HAVE_DARWIN_OS
-       (cd $<; cp scripts/makefile.macosx Makefile && make && make install)
+       (cd $<; cp scripts/makefile.darwin Makefile && make && make install)
 else
 ifdef HAVE_WIN32
        (cd $<; rm -f INSTALL; cp scripts/makefile.cygwin Makefile && make $(HOSTCC) && make install-static)
+else
+ifeq ($(PNG_VERSION),1.2.8)
+       (cd $<; PREFIX=$(PREFIX) DESTDIR=$(PREFIX) cp scripts/makefile.linux Makefile && make && make install)
 else
        (cd $<; $(HOSTCC) ./configure $(HOSTCONF) --prefix=$(PREFIX) && make && make install)
+endif
 endif
        $(INSTALL_NAME)
 endif 
@@ -1432,10 +1508,14 @@ libgpg-error-$(GPGERROR_VERSION).tar.gz:
 
 libgpg-error: libgpg-error-$(GPGERROR_VERSION).tar.gz
        $(EXTRACT_GZ)
+       patch -p 0 < Patches/libgpg-error.patch
 
 .gpg-error: libgpg-error
-       (cd $<; ./autogen.sh && libtoolize --force && $(HOSTCC) ./configure $(HOSTCONF) --prefix=$(PREFIX) --disable-nls && make && make install)
-       $(INSTALL_NAME)
+ifeq ($(HOST),i686-apple-darwin8)
+       (cd $<; ./autogen.sh)
+endif
+       (cd $<; $(HOSTCC) ./configure $(HOSTCONF) --prefix=$(PREFIX) --disable-nls --disable-shared && make && make install)
+#      $(INSTALL_NAME)
        touch $@
 
 CLEAN_FILE += .gpg-error
@@ -1455,8 +1535,11 @@ libgcrypt: libgcrypt-$(GCRYPT_VERSION).tar.bz2
 
 .gcrypt: libgcrypt .gpg-error
 ifdef HAVE_WIN32
-       (cd $<; ./autogen.sh && $(HOSTCC) ./configure $(HOSTCONF) --target=i586-mingw32msvc --prefix=$(PREFIX) CFLAGS="$(CFLAGS)" && make && make install)
+       (cd $<; ./autogen.sh && $(HOSTCC) ./configure $(HOSTCONF) --target=i586-mingw32msvc --prefix=$(PREFIX) --program-prefix="" CFLAGS="$(CFLAGS)" && echo -n "#undef HAVE_GETTIMEOFDAY" >> config.h && make && make install)
 else
+ifeq ($(HOST),i686-apple-darwin8)
+       (cd $<; $(HOSTCC) ./configure $(HOSTCONF) --prefix=$(PREFIX) --disable-asm CFLAGS="$(CFLAGS)" && make && make install)
+endif
        (cd $<; $(HOSTCC) ./configure $(HOSTCONF) --prefix=$(PREFIX) CFLAGS="$(CFLAGS)" && make && make install)
 endif
        $(INSTALL_NAME)
@@ -1475,13 +1558,13 @@ gnutls-$(GNUTLS_VERSION).tar.bz2:
 
 gnutls: gnutls-$(GNUTLS_VERSION).tar.bz2
        $(EXTRACT_BZ2)
-       (cd gnutls/gl ;ln -s alloca_.h alloca.h)
+       patch -p0 < Patches/gnutls-win32.patch
 
 .gnutls: gnutls .gcrypt .gpg-error
 ifdef HAVE_WIN32
-       (cd $<; $(HOSTCC) ./configure $(HOSTCONF) --prefix=$(PREFIX) CFLAGS="$(CFLAGS)" --target=i586-mingw32msvc && cd gl && make &&  cd ../lib &&make && make install && cd ../includes && make install)
+       (cd $<; $(HOSTCC) ./configure $(HOSTCONF) --prefix=$(PREFIX) CFLAGS="$(CFLAGS)" --target=i586-mingw32msvc --program-prefix="" && cd gl && make &&  cd ../lib &&make && make install && cd ../includes && make install)
 else
-       (cd $<; $(HOSTCC) ./configure $(HOSTCONF) --prefix=$(PREFIX) CFLAGS="$(CFLAGS)" && cd crypto && make && cd ../gl && make &&  cd ../lib &&make && make install && cd ../includes && make install)
+       (cd $<; $(HOSTCC) ./configure $(HOSTCONF) --prefix=$(PREFIX) CFLAGS="$(CFLAGS)" && cd gl && make &&  cd ../lib &&make && make install && cd ../includes && make install)
 endif
        $(INSTALL_NAME)
        touch $@
@@ -1569,27 +1652,22 @@ DISTCLEAN_PKG += gecko-sdk-ppc-macosx10.2-1.7.5.tar.gz
 # Gecko SDK win32
 # ***************************************************************************
 
-gecko-sdk-i586-pc-msvc-1.7.5.zip:
+gecko-sdk-i586-pc-msvc-1.8b1.zip:
        $(WGET) $(GECKO_SDK_WIN32_URL)
 
 libIDL-0.6.3-win32-bin.zip:
        $(WGET) $(LIBIDL_WIN32_BIN_URL)
 
-vc71-glib-1.2.10-bin.zip:
-       $(WGET) $(VC71_GLIB_WIN32_BIN_URL)
+glib-19990228.zip:
+       $(WGET) $(GLIB_WIN32_BIN_URL)
 
-gecko-sdk-win32: gecko-sdk-i586-pc-msvc-1.7.5.zip libIDL-0.6.3-win32-bin.zip vc71-glib-1.2.10-bin.zip
-       unzip  gecko-sdk-i586-pc-msvc-1.7.5.zip
+.gecko-win32: gecko-sdk-i586-pc-msvc-1.8b1.zip libIDL-0.6.3-win32-bin.zip glib-19990228.zip
+       unzip gecko-sdk-i586-pc-msvc-1.8b1.zip
        rm -rf ../gecko-sdk
        mv gecko-sdk ..
-       unzip libIDL-0.6.3-win32-bin.zip
-       unzip vc71-glib-1.2.10-bin.zip
-       mv libIDL-0.6.3-win32-bin/libIDL-0.6.dll ../gecko-sdk/bin
-       rm -rf libIDL-0.6.3-win32-bin
-       mv vc71/bin/glib-1.2.dll ../gecko-sdk/bin
-       rm -rf vc71
-
-.gecko-win32: gecko-sdk-win32
+       unzip -j libIDL-0.6.3-win32-bin.zip libIDL-0.6.3-win32-bin/libIDL-0.6.dll -d ../gecko-sdk/bin
+       unzip glib-19990228.zip glib-1.2.dll -d ../gecko-sdk/bin
+       chmod a+x ../gecko-sdk/bin/*
        touch $@
 
 CLEAN_FILE += .gecko-win32
@@ -1639,20 +1717,15 @@ DISTCLEAN_PKG += jpeg-$(JPEG_VERSION).tar.gz
 
 tiff-$(TIFF_VERSION).tar.gz:
        $(WGET) $(TIFF_URL)
-       mv tiff-$(TIFF_VERSION)-tar.gz $@
 
 tiff: tiff-$(TIFF_VERSION).tar.gz 
        $(EXTRACT_GZ)
-       patch -p 0 < Patches/tiff.patch
-ifneq ($(HOST),$(BUILD))
-       patch -p 0 < Patches/tiff-cross.patch
-endif
 
 .tiff: tiff
 ifdef HAVE_WIN32
-       (cd $<;  ./configure  --noninteractive --target=$(HOST) --with-CC=$(HOST)-gcc --with-DIR_BIN=$(PREFIX)/bin --with-DIR_LIB=$(PREFIX)/lib --with-DIR_INC=$(PREFIX)/include --with-CFLAGS="$(CFLAGS)" --with-JPEG=no --with-ZIP=no  && make -C libtiff && make -C libtiff install)
+       (cd $<; ./configure  --target=i586-mingw32msvc --with-CFLAGS="$(CFLAGS)" --with-JPEG=no --with-ZIP=no --prefix=$(PREFIX) --host=$(HOST) &&make -C port && make -C libtiff && make -C libtiff install)
 else
-       (cd $<; ./configure --noninteractive --with-DIR_BIN=$(PREFIX)/bin --with-DIR_LIB=$(PREFIX)/lib --with-DIR_INC=$(PREFIX)/include --with-CFLAGS="$(CFLAGS)" --with-JPEG=no --with-ZIP=no && make -C libtiff && make -C libtiff install)
+       (cd $<; ./configure --with-CFLAGS="$(CFLAGS)" --with-JPEG=no --with-ZIP=no --prefix=$(PREFIX) && make -C port &&make -C libtiff && make -C libtiff install)
 endif
        touch $@
 
@@ -1669,10 +1742,9 @@ SDL-$(SDL_VERSION).tar.gz:
 
 SDL: SDL-$(SDL_VERSION).tar.gz 
        $(EXTRACT_GZ)
-       patch -p 0 < Patches/SDL.patch
 
 .SDL: SDL
-       (cd $<; $(HOSTCC) ./configure $(HOSTCONF) --prefix=$(PREFIX) --disable-audio --disable-video-x11 --disable-video-aalib --disable-video-dga --disable-video-fbcon --disable-video-directfb --disable-video-ggi --disable-video-svga --disable-directx --disable-joystick --disable-cdrom --disable-threads --disable-sdl-dlopen CFLAGS="$(CFLAGS)" && make && make install)
+       (cd $<; $(HOSTCC) ./configure $(HOSTCONF) --prefix=$(PREFIX) --disable-audio --disable-video-x11 --disable-video-aalib --disable-video-dga --disable-video-fbcon --disable-video-directfb --disable-video-ggi --disable-video-svga --disable-directx --enable-joystick --disable-cdrom --disable-threads --disable-sdl-dlopen CFLAGS="$(CFLAGS)" && make && make install)
        $(INSTALL_NAME)
        touch $@
 
@@ -1692,7 +1764,7 @@ SDL_image: SDL_image-$(SDL_IMAGE_VERSION).tar.gz
        patch -p 0 < Patches/SDL_image.patch
 
 .SDL_image: SDL_image .SDL .png .jpeg .tiff
-       (cd $<; $(HOSTCC) ./configure $(HOSTCONF) --prefix=$(PREFIX) --enable-tif CFLAGS="$(CFLAGS)" && make && make install)
+       (cd $<; $(HOSTCC) ./configure $(HOSTCONF) --prefix=$(PREFIX) CFLAGS="$(CFLAGS)" --enable-tif --disable-sdltest && make && make install)
        $(INSTALL_NAME)
        touch $@
 
@@ -1738,6 +1810,9 @@ dirac-$(DIRAC_VERSION).tar.gz:
 
 dirac: dirac-$(DIRAC_VERSION).tar.gz
        $(EXTRACT_GZ)
+ifdef HAVE_DARWIN_OS
+       patch -p 0 <Patches/dirac-osx.patch
+endif
 ifneq ($(HOST),$(BUILD))
        patch -p 0 <Patches/dirac-cross.patch
        (cd $@; aclocal && autoconf && automake)
@@ -1745,6 +1820,14 @@ endif
 
 .dirac: dirac
        (cd $<; $(HOSTCC) ./configure $(HOSTCONF) --prefix=$(PREFIX)  CFLAGS="$(CFLAGS)" && DOC_DIR="" make && DOC_DIR="" make install)
+       touch $@
+
+# for MacOS X, dirac is split into two libraries, which needs be installed using two targets
+.dirac_encoder: .dirac
+       $(INSTALL_NAME)
+       touch $@
+
+.dirac_decoder: .dirac
        $(INSTALL_NAME)
        touch $@
 
@@ -1785,6 +1868,9 @@ expat: expat-$(EXPAT_VERSION).tar.gz
        $(EXTRACT_GZ)
 
 .expat: expat
+ifdef HAVE_DARWIN_OS
+       (cd $< aclocal --force && libtoolize --force && autoconf --force && autoheader --force )
+endif
        (cd $<; ./configure --prefix=$(PREFIX) && make && make install)
        touch $@
 
@@ -1851,6 +1937,40 @@ DISTCLEAN_PKG += nasm-$(NASM_VERSION).tar.bz2
 
 CLEAN_FILE += .aclocal
 
+# ***************************************************************************
+# UNICOWS (Unicode support for WINME/98/95)
+# ***************************************************************************
+
+libunicows-$(UNICOWS_VERSION).tar.gz:
+       $(WGET) $(UNICOWS_URL)
+       mv libunicows-$(UNICOWS_VERSION)-src.tar.gz $@ || true
+
+libunicows: libunicows-$(UNICOWS_VERSION).tar.gz
+       $(EXTRACT_GZ)
+
+.unicows: libunicows
+       (cd $</src; make -f makefile.mingw32 PATHSEP='/' $(HOSTCC) && cp -f ../lib/mingw32/libunicows.a $(PREFIX)/lib)
+       touch $@
+
+CLEAN_FILE += .unicows
+CLEAN_PKG += libunicows
+DISTCLEAN_PKG += libunicows-$(UNICOWS_VERSION)-src.tar.gz
+
+# ***************************************************************************
+# TagLib read and editing of tags of popular audio formats
+# ***************************************************************************
+
+taglib-$(TAGLIB_VERSION).tar.gz:
+       $(WGET) $(TAGLIB_URL)
+
+taglib: taglib-$(TAGLIB_VERSION).tar.gz
+       $(EXTRACT_GZ)
+
+.tag: taglib
+       (cd $<; $(HOSTCC) ./configure $(HOSTCONF) --prefix=$(PREFIX) && make && make install)
+       $(INSTALL_NAME)
+       touch $@
+
 # ***************************************************************************
 # Some cleansing
 # ***************************************************************************
@@ -1865,3 +1985,4 @@ clean-src: clean
        rm -rf $(DISTCLEAN_PKG)
 
 distclean: clean-src
+