]> git.sesse.net Git - vlc/blobdiff - extras/contrib/src/Makefile
* extras/contrib/src/Makefile: removed a nonexistent patch that I did not
[vlc] / extras / contrib / src / Makefile
index 73edcd58b81dc92b03e9a4782a3fe1cd2898c774..068fa4c2f9958caefb08917d2c7d40d343f8ba99 100644 (file)
@@ -1,11 +1,15 @@
 # ***************************************************************************
 # src/Makefile : Dearchive and compile all files necessary
 # ***************************************************************************
-# Copyright (C) 2003, 2004, 2005 the VideoLAN team
+# Copyright (C) 2003 - 2005 the VideoLAN team
 # $Id$
 #
 # Authors: Christophe Massiot <massiot@via.ecp.fr>
 #          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>
+#          Gildas Bazin <gbazin 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
@@ -19,7 +23,7 @@
 #
 # You should have received a copy of the GNU General Public License
 # along with this program; if not, write to the Free Software
-# Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA  02111, USA.
+# Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston MA 02110-1301, USA.
 # ***************************************************************************
 
 include ../config.mak
@@ -29,29 +33,10 @@ include ./packages.mak
 # Set a clean environment
 # ***************************************************************************
 
-ifeq ($(HOST),ppc-darwin)
-HAVE_DARWIN_OS=1
-endif
-ifeq ($(HOST),powerpc-apple-darwin8)
-HAVE_DARWIN_OS=1
-endif
-
-ifdef HAVE_DARWIN_OS
-export PATH = $(PREFIX)/bin:/bin:/usr/bin
+export PATH := $(PREFIX)/bin:$(EXTRA_PATH):$(PATH)
+export PKG_CONFIG_PATH
 export DYLD_LIBRARY_PATH = $(PREFIX)/lib
-endif
-
-ifeq ($(HOST),i586-pc-beos)
-ifeq ($(HOST),$(BUILD))
-# Compiling on BeOS
-export PATH = $(PREFIX)/bin:.:/boot/home/config/bin:/bin:/boot/apps:/boot/preferences:/boot/beos/apps:/boot/beos/preferences:/boot/develop/tools/gnupro/bin
-export LIBRARY_PATH = $(PREFIX)/lib:%A/lib:/boot/home/config/lib:/boot/beos/system/lib
-else
-# Cross compiling from Linux
-export PATH = $(PREFIX)/bin:/opt/cross-tools/bin:/usr/bin:/bin
-endif
-endif
-
+export LIBRARY_PATH := $(PREFIX)/lib:$(LIBRARY_PATH)
 export CFLAGS = -I$(PREFIX)/include $(EXTRA_CFLAGS) $(EXTRA_CPPFLAGS)
 export CPPFLAGS = -I$(PREFIX)/include $(EXTRA_CFLAGS) $(EXTRA_CPPFLAGS)
 export CXXFLAGS = -I$(PREFIX)/include $(EXTRA_CFLAGS) $(EXTRA_CPPFLAGS)
@@ -64,17 +49,66 @@ export LDFLAGS = -L$(PREFIX)/lib $(EXTRA_LDFLAGS)
 # way of doing it... ;)
 # ***************************************************************************
 
+ifneq ($(CC),)
+HOSTCC+= CC="$(CC)"
+endif
+ifneq ($(CXX),)
+HOSTCC+= CXX="$(CXX)"
+endif
+ifneq ($(LD),)
+HOSTCC+= LD="$(LD)"
+endif
+ifneq ($(RANLIB),)
+HOSTCC+= RANLIB="$(RANLIB)"
+endif
+ifneq ($(AR),)
+HOSTCC+= AR="$(AR)"
+endif
+
+# Define ranlib on non-cross compilation setups
+ifeq ($(RANLIB),)
+RANLIB=ranlib
+endif
+
+# For libebml/libmatroska. Grrr.
+ifneq ($(AR),)
+HOSTCC2=$(HOSTCC) AR="$(AR) rcvu"
+else
+HOSTCC2=$(HOSTCC)
+endif
+
 ifneq ($(BUILD),$(HOST))
 # We are cross compiling
-HOSTCONF=--host=$(HOST)
-HOSTCC=CC=$(HOST)-gcc CXX=$(HOST)-g++ AR=$(HOST)-ar RANLIB=$(HOST)-ranlib
-# For libebml/libmatroska. Grrr.
-HOSTCC2=CC=$(HOST)-gcc CXX=$(HOST)-g++ "AR=$(HOST)-ar rcvu" RANLIB=$(HOST)-ranlib
+HOSTCONF=--host=$(HOST) --build=$(BUILD)
 FFMPEGCONF=--cross-prefix=$(HOST)-
-RANLIB=$(HOST)-ranlib
+X264CONF=--crosscompile=$(HOST)
 else
-# Building natively
-RANLIB=ranlib
+   ifneq ($(CC),)
+      FFMPEGCONF=--cc="$(CC)"
+   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
+FFMPEGCONF+= --enable-mingw32 --enable-memalign-hack --cpu=x86 --disable-debug
+endif
+
+ifdef HAVE_WINCE
+HOSTCONF+= --without-pic --disable-shared
+FFMPEGCONF+= --enable-mingwce --cpu=armv4l --disable-debug --disable-encoders --disable-muxers --disable-mpegaudio-hp --disable-codec=snow --disable-codec=vc9 --disable-codec=wmv3 --disable-codec=vorbis --disable-codec=vorbis --disable-codec=dvdsub --disable-codec=dvbsub --disable-protocols
+else
+FFMPEGCONF+= --enable-mp3lame --enable-faac
+endif
+
+ifdef HAVE_BEOS
+FFMPEGCONF+= --cpu=x86
+endif
+
+ifeq ($(HOST),i686-apple-darwin8)
+FFMPEGCONF += --enable-memalign-hack
 endif
 
 # ***************************************************************************
@@ -82,36 +116,63 @@ endif
 # ***************************************************************************
 
 ifdef HAVE_DARWIN_OS
- all: .autoconf .libtool .automake .iconv .intl .pkgcfg .freetype .fribidi \
-       .a52 .mpeg2 .id3tag .mad .ogg .vorbis .vorbisenc .x264 .theora \
-       .FLAC .speex .shout .faad .faac .lame .twolame .ebml .matroska .ffmpeg .openslp \
-       .dvdcss .dvdread .dvdnav .dvbpsi .live .goom2k4 .caca .mod \
-       .png .gpg-error .gcrypt .gnutls .daap .cddb .cdio .vcdimager .SDL_image \
-       .aclocal
-# mozilla support? add before .aclocal:  .glib .libidl .mozilla
+ all: .autoconf .automake .libtool .iconv .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 .caca .mod \
+       .png .gpg-error .gcrypt .gnutls .opendaap .cddb .cdio .vcdimager .SDL_image \
+       .glib .libidl .gecko .mpcdec .expat .clinkcc .aclocal
+# .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: .x264 .goom2k4
+endif
 else
 
- ifeq ($(HOST),i586-pc-beos)
+ ifdef HAVE_BEOS
   ifeq ($(HOST),$(BUILD))
 # Native build: we need perl, autoconf, etc first
-   all: .perl .autoconf .libtool .automake .iconv .intl .freetype .fribidi \
+   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 \
-       .dvdread .dvdnav .dvbpsi .aclocal
+       .dvdnav .dvbpsi .aclocal
   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 \
-       .dvdread .dvdnav .dvbpsi .aclocal
+       .dvdnav .dvbpsi .aclocal
   endif
  else
+
+  ifdef HAVE_WIN32
+
+   all: .iconv .intl .freetype .fribidi .zlib \
+       .a52 .mpeg2 .id3tag .mad .ogg .vorbis .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 
+  else
+
+   ifdef HAVE_WINCE
+
+   all: .dvbpsi .zlib .ffmpeg .ogg .tremor .faad
+   else
+
 # Standard Linux or other UNIX-like systems
-   all: .iconv .intl .freetype .fribidi \
+   all: .iconv .intl .freetype .fribidi .zlib \
        .a52 .mpeg2 .id3tag .mad .ogg .vorbis .vorbisenc .theora \
-       .FLAC .speex .faad .faac .lame .ebml .matroska .ffmpeg .dvdcss \
-       .dvdread .dvdnav .dvbpsi .aclocal
+       .FLAC .speex .faad .faac .lame .ebml .dts .matroska .ffmpeg .dvdcss \
+       .live .goom2k4 .caca .mod .x264  .xml .twolame\
+       .png .gpg-error .gcrypt .gnutls .mpcdec\
+       .gnutls .dvdnav .dvbpsi .wxwidgets .dirac \
+       .aclocal 
+#      .SDL_image  .daap .cddb .cdio .vcdimager 
+   endif
+  endif
  endif
 endif
 
@@ -226,8 +287,13 @@ DISTCLEAN_PKG += autoconf-$(AUTOCONF_VERSION).tar.gz
 ifdef HAVE_DARWIN_OS
 .libtool:
        if test -x /usr/bin/glibtoolize; then \
+               mkdir -p $(PREFIX)/bin ; \
                ln -sf /usr/bin/glibtoolize $(PREFIX)/bin/libtoolize ; \
        fi
+       if test -f /usr/share/aclocal/libtool.m4; then \
+               mkdir -p $(PREFIX)/share/aclocal ; \
+               ln -sf /usr/share/aclocal/libtool.m4 $(PREFIX)/share/aclocal ; \
+       fi
        touch $@
 endif
 
@@ -293,10 +359,16 @@ gettext-$(GETTEXT_VERSION).tar.gz:
 
 gettext: gettext-$(GETTEXT_VERSION).tar.gz
        $(EXTRACT_GZ)
-       patch -p 0 < Patches/gettext.patch
+ifdef HAVE_DARWIN_OS
+       patch -p 0 < Patches/gettext-osx.patch
+endif
 
 .intl: gettext .iconv
-       ( cd $< && ./configure $(HOSTCONF) --prefix=$(PREFIX) )
+ifdef HAVE_WIN32
+       ( cd $< && $(HOSTCC) ./configure $(HOSTCONF) --prefix=$(PREFIX) --disable-relocatable --with-iconv-prefix=$(PREFIX))
+else
+       ( cd $< && $(HOSTCC) ./configure $(HOSTCONF) --prefix=$(PREFIX) )
+endif
 ifeq ($(BUILD),i586-pc-beos)
 # The ugliest kludge ever - so libtool correctly links shared libraries
 # on BeOS. Sorry, I just can't figure out how libtool works
@@ -308,6 +380,10 @@ ifneq ($(HOST),$(BUILD))
 else
 # Build and install the whole gettext
        ( cd $< && make && make install )
+endif
+# Work around another non-sense of autoconf.
+ifdef HAVE_WIN32
+       (cd ../include; sed -i.bak '283 c #if !1' libintl.h)
 endif
        $(INSTALL_NAME)
        touch $@
@@ -325,10 +401,16 @@ libiconv-$(LIBICONV_VERSION).tar.gz:
 
 libiconv: libiconv-$(LIBICONV_VERSION).tar.gz
        $(EXTRACT_GZ)
+ifdef HAVE_DARWIN_OS
        patch -p 0 < Patches/libiconv.patch
+endif
 
 .iconv: libiconv
-       (cd libiconv; ./configure $(HOSTCONF) --prefix=$(PREFIX) --disable-nls && make && make install)
+ifdef HAVE_DARWIN_OS
+       (cd libiconv; $(HOSTCC) ./configure $(HOSTCONF) --prefix=$(PREFIX) --disable-nls && make && make install)
+else
+       (cd libiconv; CPPFLAGS="-Dssize_t=long" $(HOSTCC) ./configure $(HOSTCONF) --prefix=$(PREFIX) --disable-nls && make && make install)
+endif
        $(INSTALL_NAME)
        touch $@
 
@@ -347,7 +429,7 @@ freetype2: freetype-$(FREETYPE2_VERSION).tar.gz
        $(EXTRACT_GZ)
 
 .freetype: freetype2
-       (cd $<; ./configure $(HOSTCONF) --prefix=$(PREFIX) && make && make install)
+       (cd $<; $(HOSTCC) ./configure $(HOSTCONF) --prefix=$(PREFIX) && make && make install)
        $(INSTALL_NAME)
        touch $@
 
@@ -365,9 +447,11 @@ fribidi-$(FRIBIDI_VERSION).tar.gz:
 fribidi: fribidi-$(FRIBIDI_VERSION).tar.gz
        $(EXTRACT_GZ)
        patch -p 0 < Patches/fribidi.patch.real
-
-.fribidi: fribidi
-       (cd $<; ./bootstrap && ./configure $(HOSTCONF) --prefix=$(PREFIX) && make && make install)
+ifdef HAVE_WIN32
+       patch -p 0 <Patches/fribidi-win32.patch
+endif
+.fribidi: fribidi .iconv
+       (cd $<; rm -f configure; ./bootstrap && $(HOSTCC) ./configure $(HOSTCONF) --prefix=$(PREFIX)  && make && make install)
        $(INSTALL_NAME)
        touch $@
 
@@ -386,7 +470,7 @@ a52dec: a52dec-$(A52DEC_VERSION).tar.gz
        $(EXTRACT_GZ)
 
 .a52: a52dec
-       (cd $<; ./configure $(HOSTCONF) --prefix=$(PREFIX) && make && make install)
+       (cd $<; $(HOSTCC) ./configure $(HOSTCONF) --prefix=$(PREFIX) && cd liba52 && make && make install && cd ../include && make && make install)
        touch $@
 
 CLEAN_FILE += .a52
@@ -416,7 +500,7 @@ mpeg2dec: mpeg2dec-$(MPEG2DEC_VERSION).tar.gz
        patch -p 0 < Patches/mpeg2dec.patch
 
 .mpeg2: mpeg2dec
-       (cd $<; ./configure $(HOSTCONF) --prefix=$(PREFIX) --without-x --disable-sdl && make && make install)
+       (cd $<; $(HOSTCC) ./configure $(HOSTCONF) --prefix=$(PREFIX) --without-x --disable-sdl && cd libmpeg2 && make && make install && cd ../include && make && make install)
        touch $@
 
 CLEAN_FILE += .mpeg2
@@ -435,7 +519,7 @@ libid3tag: libid3tag-$(LIBID3TAG_VERSION).tar.gz
        $(EXTRACT_GZ)
 
 .id3tag: libid3tag
-       (cd $<; ./configure $(HOSTCONF) --prefix=$(PREFIX) && make && make install)
+       (cd $<; $(HOSTCC) ./configure $(HOSTCONF) --prefix=$(PREFIX) && make && make install)
        $(INSTALL_NAME)
        touch $@
 
@@ -454,7 +538,7 @@ libmad: libmad-$(LIBMAD_VERSION).tar.gz
        $(EXTRACT_GZ)
 
 .mad: libmad
-       (cd $<; ./configure $(HOSTCONF) --prefix=$(PREFIX) CFLAGS="-O3" && make && make install)
+       (cd $<; $(HOSTCC) ./configure $(HOSTCONF) --prefix=$(PREFIX) CFLAGS="-O3" && make && make install)
        $(INSTALL_NAME)
        touch $@
 
@@ -478,9 +562,12 @@ libogg-$(OGG_VERSION).tar.gz:
 libogg: libogg-$(OGG_VERSION).tar.gz
        $(EXTRACT_GZ)
        patch -p 0 < Patches/ogg.patch
+ifdef HAVE_WINCE
+       patch -p 0 < Patches/libogg-wince.patch
+endif
 
 .ogg: libogg
-       (cd $<; ./configure $(HOSTCONF) --prefix=$(PREFIX) && make && make install)
+       (cd $<; $(HOSTCC) ./configure $(HOSTCONF) --prefix=$(PREFIX) && make install)
        $(INSTALL_NAME)
        touch $@
 
@@ -506,11 +593,9 @@ libvorbis: libvorbis-$(VORBIS_VERSION).tar.gz
        $(EXTRACT_GZ)
 
 .vorbis: libvorbis .ogg
-# libvorbis' configure doesn't handle --host
-# FIXME: shared libs disabled for now because configure thinks we should
-# link the .so to -lc when cross-compiling to BeOS (-> fails)
-#   -- titer 2005/02/12
-       (cd $<; $(HOSTCC) ./configure --prefix=$(PREFIX) --disable-shared && make && make install)
+# FIXME: shared libs disabled for now because of linking errors
+#   -- titer 2005/09/16
+       (cd $<; $(HOSTCC) ./configure $(HOSTCONF) --prefix=$(PREFIX) --disable-shared && make && make install)
 #      $(INSTALL_NAME)
        touch $@
 
@@ -522,6 +607,32 @@ CLEAN_FILE += .vorbis .vorbisenc
 CLEAN_PKG += libvorbis
 DISTCLEAN_PKG += libvorbis-$(VORBIS_VERSION).tar.gz
 
+# ***************************************************************************
+# tremor
+# ***************************************************************************
+
+ifdef SVN
+tremor: 
+       $(SVN) co http://svn.xiph.org/trunk/Tremor tremor
+       (cd $@ && patch -p0 < ../Patches/tremor.patch)
+       (cd $@; rm -f ogg.h && echo "#include <ogg/ogg.h>" > ogg.h && rm -f os_types.h && echo "#include <ogg/os_types.h>" > os_types.h && ./autogen.sh)
+else
+tremor-$(TREMOR_VERSION).tar.bz2:
+       $(WGET) $(TREMOR_URL)
+
+tremor: tremor-$(TREMOR_VERSION).tar.bz2
+       $(EXTRACT_BZ2)
+endif
+
+.tremor: tremor .ogg
+       (cd $<; $(HOSTCC) ./configure $(HOSTCONF) --prefix=$(PREFIX) --disable-shared && make && make install)
+       $(INSTALL_NAME)
+       touch $@
+
+CLEAN_FILE += .tremor
+CLEAN_PKG += tremor
+DISTCLEAN_PKG += tremor-$(TREMOR_VERSION).tar.gz
+
 # ***************************************************************************
 # theora
 # ***************************************************************************
@@ -533,8 +644,8 @@ libtheora: libtheora-$(THEORA_VERSION).tar.bz2
        $(EXTRACT_BZ2)
        patch -p0 < Patches/theora.patch
 
-.theora: libtheora
-       (cd $<; ./configure $(HOSTCONF) --prefix=$(PREFIX) --disable-sdltest --disable-oggtest --disable-vorbistest && make && make install)
+.theora: libtheora .ogg
+       (cd $<; $(HOSTCC) ./configure $(HOSTCONF) --prefix=$(PREFIX) --disable-sdltest --disable-oggtest --disable-vorbistest && make && make install)
        $(INSTALL_NAME)
        touch $@
 
@@ -552,8 +663,8 @@ libshout-$(SHOUT_VERSION).tar.gz:
 libshout: libshout-$(SHOUT_VERSION).tar.gz
        $(EXTRACT_GZ)
 
-.shout: libshout
-       (cd $<; ./configure $(HOSTCONF) --prefix=$(PREFIX) && make && make install)
+.shout: libshout .theora .ogg
+       (cd $<; $(HOSTCC) ./configure $(HOSTCONF) --prefix=$(PREFIX) && make && make install)
        $(INSTALL_NAME)
        touch $@
 
@@ -570,9 +681,19 @@ flac-$(FLAC_VERSION).tar.gz:
 
 flac: flac-$(FLAC_VERSION).tar.gz
        $(EXTRACT_GZ)
+ifdef HAVE_DARWIN_OS
+       patch -p 0 < Patches/flac-mactel.patch
+endif
+ifneq ($(HOST),$(BUILD))
+       (patch -p 0 < Patches/flac-cross.patch && cd $@ && autoconf)
+endif
 
-.FLAC: flac
-       (cd $<; ./configure $(HOSTCONF) --prefix=$(PREFIX) && make && make install)
+.FLAC: flac 
+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 $<; $(HOSTCC) ./configure $(HOSTCONF) --prefix=$(PREFIX) --disable-oggtest && cd src&& make -C libFLAC&& make -C libFLAC install  && cd .. && make -C include install)
+endif
        $(INSTALL_NAME)
        touch $@
 
@@ -592,7 +713,7 @@ speex: speex-$(SPEEX_VERSION).tar.gz
        patch -p0 < Patches/speex.patch
 
 .speex: speex
-       (cd $<; ./configure $(HOSTCONF) --prefix=$(PREFIX) --enable-ogg=no && make && make install)
+       (cd $<; $(HOSTCC) ./configure $(HOSTCONF) --prefix=$(PREFIX) --enable-ogg=no && make && make install)
        $(INSTALL_NAME)
        touch $@
 
@@ -616,10 +737,13 @@ faad2-$(FAAD2_VERSION).tar.bz2:
 
 faad2: faad2-$(FAAD2_VERSION).tar.bz2
        $(EXTRACT_BZ2)
+       (cd $@; patch -p 0  < ../Patches/faad2.patch && ./bootstrap)
 
 .faad: faad2
-       (cd $<; ./configure $(HOSTCONF) --prefix=$(PREFIX) CFLAGS="-O3" && make -C libfaad && make -C libfaad install)
+       (cd $< && $(HOSTCC) ./configure $(HOSTCONF) --prefix=$(PREFIX) CFLAGS="-O3" && make -C libfaad && make -C libfaad install)
+ifndef HAVE_DARWIN_OS
        $(INSTALL_NAME)
+endif
        touch $@
 
 CLEAN_FILE += .faad
@@ -638,7 +762,7 @@ faac: faac-$(FAAC_VERSION).tar.bz2
        patch -p 0 < Patches/faac.patch
 
 .faac: faac
-       (cd $<; rm -f install-sh mkinstalldirs missing && ./bootstrap && ./configure $(HOSTCONF) --prefix=$(PREFIX) --disable-shared && make && make install)
+       (cd $<; rm -f install-sh mkinstalldirs missing && ./bootstrap && $(HOSTCC) ./configure $(HOSTCONF) --prefix=$(PREFIX) --disable-shared && make && make install)
        touch $@
 
 CLEAN_FILE += .faac
@@ -656,7 +780,7 @@ lame: lame-$(LAME_VERSION).tar.gz
        $(EXTRACT_GZ)
 
 .lame: lame
-       (cd $<; ./configure $(HOSTCONF) --prefix=$(PREFIX) --disable-shared && make && make install)
+       (cd $<; $(HOSTCC) ./configure $(HOSTCONF) --prefix=$(PREFIX) --disable-analyser-hooks --disable-decoder --disable-shared --disable-gtktest --disable-frontend && make && make install)
        touch $@
 
 CLEAN_FILE += .lame
@@ -668,7 +792,7 @@ DISTCLEAN_PKG += lame-$(LAME_VERSION).tar.gz
 # ***************************************************************************
 
 ifdef SVN
-libebml:
+libebml: 
        $(SVN) co http://svn.matroska.org/svn/matroska/trunk/libebml libebml
 else
 libebml-$(LIBEBML_VERSION).tar.bz2:
@@ -677,10 +801,17 @@ libebml-$(LIBEBML_VERSION).tar.bz2:
 libebml: libebml-$(LIBEBML_VERSION).tar.bz2
        $(EXTRACT_BZ2)
 endif
+ifdef HAVE_WIN32
+       (cd $@; patch -p 0 < ../Patches/libebml-svn-win32.patch)
+endif
 
 .ebml: libebml
+ifdef HAVE_WIN32
+       (cd $<; make -C make/mingw32 prefix=$(PREFIX) $(HOSTCC2) CFLAGS="$(CFLAGS) -DWIN32" SHARED=no && make -C make/linux install_staticlib install_headers prefix=$(PREFIX) $(HOSTCC2))
+else
        (cd $<; make -C make/linux prefix=$(PREFIX) $(HOSTCC2) staticlib && make -C make/linux install_staticlib install_headers prefix=$(PREFIX))
        $(RANLIB) $(PREFIX)/lib/libebml.a
+endif  
        touch $@
 
 CLEAN_FILE += .ebml
@@ -701,10 +832,17 @@ libmatroska-$(LIBMATROSKA_VERSION).tar.bz2:
 libmatroska: libmatroska-$(LIBMATROSKA_VERSION).tar.bz2
        $(EXTRACT_BZ2)
 endif
+ifdef HAVE_WIN32
+       (cd $@; patch -p 0 < ../Patches/libmatroska-win32.patch)
+endif
 
-.matroska: libmatroska
+.matroska: libmatroska .ebml
+ifdef HAVE_WIN32
+       (cd $<; make -C make/mingw32 prefix=$(PREFIX) $(HOSTCC2) SHARED=no EBML_DLL=no libmatroska.a && make -C make/linux install_staticlib install_headers prefix=$(PREFIX) $(HOSTCC2))
+else
        (cd $<; make -C make/linux prefix=$(PREFIX) $(HOSTCC2) staticlib && make -C make/linux install_staticlib install_headers prefix=$(PREFIX))
        $(RANLIB) $(PREFIX)/lib/libmatroska.a
+endif
        touch $@
 
 CLEAN_FILE += .matroska
@@ -718,8 +856,24 @@ 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
-       patch -p 0 < Patches/ffmpeg.patch.cvs
-#      (cd $@; ./bootstrap)
+       (cd $@;patch -p 0 <../Patches/ffmpeg-cvs.patch) 
+ifeq ($(HOST),i586-pc-beos)
+       patch -p 0 < Patches/ffmpeg-beos.patch.cvs
+       (cd $@; ./bootstrap)
+endif
+ifdef HAVE_WIN32
+       patch -p 0 < Patches/ffmpeg-cvs-win32.patch
+       patch -p 1 < Patches/ffmpeg-cvs-wince.patch
+endif
+ifdef HAVE_WINCE
+       patch -p 1 < Patches/ffmpeg-cvs-wince.patch
+endif
+ifdef HAVE_DARWIN_OS
+       patch -p 0 < Patches/ffmpeg-cvs-osx.patch
+endif
+ifeq ($(HOST),i686-apple-darwin8)
+       (cd $@;patch -p 0 < ../Patches/ffmpeg-cvs-mactel.patch)
+endif
 
 ffmpeg-$(FFMPEG_VERSION).tar.gz:
        $(WGET) $(FFMPEG_URL)
@@ -728,45 +882,36 @@ ffmpeg-$(FFMPEG_VERSION).tar.gz:
 #      $(EXTRACT_GZ)
 #      patch -p 0 < Patches/ffmpeg.patch
 
-.ffmpeg: ffmpeg
-       (cd $<; ./configure $(FFMPEGCONF) --prefix=$(PREFIX) --extra-cflags="$(CFLAGS) -DRUNTIME_CPUDETECT" --extra-ldflags="$(LDFLAGS)" --enable-gpl --enable-mp3lame --enable-faac --enable-pp --disable-vhook --disable-audio-beos --disable-ffserver --disable-vorbis --disable-faad --enable-mp3lame --enable-zlib --enable-a52 --disable-ffplay && make && make -C libavcodec/libpostproc install && make -C libavcodec installlib && make -C libavformat installlib && make -C libavutil installlib)
+ifdef HAVE_WINCE
+.ffmpeg: ffmpeg .zlib
+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 && for dir in libavcodec/libpostproc libavcodec libavformat libavutil; do make -C $$dir && make -C $$dir installlib; done)
        touch $@
 
 CLEAN_FILE += .ffmpeg
 CLEAN_PKG += ffmpeg ffmpeg.cvs
 DISTCLEAN_PKG += ffmpeg-$(FFMPEG_VERSION).tar.gz
 
-# ***************************************************************************
-# openslp
-# ***************************************************************************
-
-openslp-$(OPENSLP_VERSION).tar.gz:
-       $(WGET) $(OPENSLP_URL)
-
-openslp: openslp-$(OPENSLP_VERSION).tar.gz
-       $(EXTRACT_GZ)
-       patch -p 0 < Patches/openslp.patch
-
-.openslp: openslp
-       (cd $<; ./configure --prefix=$(PREFIX) && make SUBDIRS="common libslpattr slpd libslp slptool" && make install SUBDIRS="common libslpattr slpd libslp slptool")
-       touch $@
-
-CLEAN_FILE += .openslp
-CLEAN_PKG += openslp
-DISTCLEAN_PKG += openslp-$(OPENSLP_VERSION).tar.gz
-
 # ***************************************************************************
 # libdvdcss
 # ***************************************************************************
 
+ifdef SVN
+libdvdcss: 
+       $(SVN) co svn://svn.videolan.org/libdvdcss/trunk libdvdcss
+       cd $@ && sh bootstrap
+else
 libdvdcss-$(LIBDVDCSS_VERSION).tar.gz:
        $(WGET) $(LIBDVDCSS_URL)
 
 libdvdcss: libdvdcss-$(LIBDVDCSS_VERSION).tar.gz
        $(EXTRACT_GZ)
+endif
 
 .dvdcss: libdvdcss
-       (cd $<; ./configure $(HOSTCONF) --prefix=$(PREFIX) && make && make install)
+       (cd $<; $(HOSTCC) ./configure $(HOSTCONF) --prefix=$(PREFIX) && make && make install)
        $(INSTALL_NAME)
        touch $@
 
@@ -775,49 +920,67 @@ CLEAN_PKG += libdvdcss
 DISTCLEAN_PKG += libdvdcss-$(LIBDVDCSS_VERSION).tar.gz
 
 # ***************************************************************************
-# libdvdread
+# libdvdread: We use dvdnav's dvdread
 # ***************************************************************************
 
-libdvdread-$(LIBDVDREAD_VERSION).tar.gz:
-       $(WGET) $(LIBDVDREAD_URL)
+#libdvdread-$(LIBDVDREAD_VERSION).tar.bz2:
+#      $(WGET) $(LIBDVDREAD_URL)
 
-libdvdread: libdvdread-$(LIBDVDREAD_VERSION).tar.gz
-       $(EXTRACT_GZ)
-       patch -p 0 < Patches/libdvdread.patch
+#libdvdread: libdvdread-$(LIBDVDREAD_VERSION).tar.bz2
+#      $(EXTRACT_BZ2)
+#      patch  -p 0 < Patches/libdvdread.patch
+#ifdef HAVE_WIN32
+#      if automake-1.4 --version >/dev/null 2>&1; then \
+#              echo "Please get rid of your automake 1.4"; \
+#              rm -rf $@ \
+#              exit 1; \
+#      fi
+#      (cd libdvdread; patch -p 0 < ../Patches/libdvdread-20041028-win32.patch; ./bootstrap)
+#endif
+
+#.dvdread: libdvdread .dvdcss
+#      (cd libdvdread; $(HOSTCC) ./configure $(HOSTCONF) --prefix=$(PREFIX) --with-libdvdcss=$(PREFIX) && make && make install)
+#      $(INSTALL_NAME)
+#      touch $@
+
+#CLEAN_FILE += .dvdread
+#CLEAN_PKG += libdvdread
+#DISTCLEAN_PKG += libdvdread-$(LIBDVDREAD_VERSION).tar.bz2
 
-.dvdread: libdvdread .dvdcss
-       (cd $<; ./configure $(HOSTCONF) --prefix=$(PREFIX) --with-libdvdcss=$(PREFIX) && make && make install)
+# ***************************************************************************
+# dummy dvdread to trigger the INSTALL_NAME script
+# ***************************************************************************
+.dvdread: .dvdnav
        $(INSTALL_NAME)
        touch $@
 
 CLEAN_FILE += .dvdread
-CLEAN_PKG += libdvdread
-DISTCLEAN_PKG += libdvdread-$(LIBDVDREAD_VERSION).tar.gz
 
 # ***************************************************************************
 # libdvdnav
 # ***************************************************************************
 
-libdvdnav-$(LIBDVDNAV_VERSION).tar.gz:
+libdvdnav-$(LIBDVDNAV_VERSION).tar.bz2:
        $(WGET) $(LIBDVDNAV_URL)
 
-libdvdnav: libdvdnav-$(LIBDVDNAV_VERSION).tar.gz
-       $(EXTRACT_GZ)
+libdvdnav: libdvdnav-$(LIBDVDNAV_VERSION).tar.bz2
+       $(EXTRACT_BZ2)
        patch -p 0 < Patches/dvdnav.patch
-ifdef HAVE_DARWIN_OS
-       (cd $@; autoconf)
-else
+       patch -p 0 < Patches/libdvdnav-mactel.patch
        (cd $@; ./autogen.sh noconfig)
-endif
 
-.dvdnav: libdvdnav .dvdread
-       (cd $<; ./configure $(HOSTCONF) --enable-static --prefix=$(PREFIX) --with-libdvdcss=$(PREFIX) CFLAGS="$(CFLAGS) -Dlseek64=lseek -Doff64_t=off_t" && make && make install)
+.dvdnav: libdvdnav .dvdcss
+ifdef HAVE_WIN32       
+       (cd $<; $(HOSTCC) ./configure $(HOSTCONF) --enable-static --prefix=$(PREFIX) --with-libdvdcss=$(PREFIX) CFLAGS="$(CFLAGS)" CPPFLAGS="$(CPPFLAGS) -Dssize_t=long" && make && make install)
+else
+       (cd $<; $(HOSTCC) ./configure $(HOSTCONF) --enable-static --prefix=$(PREFIX) --with-libdvdcss=$(PREFIX) CFLAGS="$(CFLAGS) -Dlseek64=lseek -Doff64_t=off_t" && make && make install)
+endif
        $(INSTALL_NAME)
        touch $@
 
 CLEAN_FILE += .dvdnav
 CLEAN_PKG += libdvdnav
-DISTCLEAN_PKG += libdvdnav-$(LIBDVDNAV_VERSION).tar.gz
+DISTCLEAN_PKG += libdvdnav-$(LIBDVDNAV_VERSION).tar.bz2
 
 # ***************************************************************************
 # libdvbpsi
@@ -830,7 +993,7 @@ libdvbpsi: libdvbpsi3-$(LIBDVBPSI_VERSION).tar.gz
        $(EXTRACT_GZ)
 
 .dvbpsi: libdvbpsi
-       (cd $<; ./configure $(HOSTCONF) --prefix=$(PREFIX) && make && make install)
+       (cd $<; $(HOSTCC) ./configure $(HOSTCONF) --prefix=$(PREFIX) && cd src && make && make install)
        $(INSTALL_NAME)
        touch $@
 
@@ -842,20 +1005,30 @@ DISTCLEAN_PKG += libdvbpsi3-$(LIBDVBPSI_VERSION).tar.gz
 # live
 # ***************************************************************************
 
-live-$(LIVEDOTCOM_VERSION).tar.gz:
+live555-$(LIVEDOTCOM_VERSION).tar.gz:
        $(WGET) $(LIVEDOTCOM_URL)
 
-live: live-$(LIVEDOTCOM_VERSION).tar.gz
+live: live555-$(LIVEDOTCOM_VERSION).tar.gz
        $(EXTRACT_GZ)
        patch -p 0 < Patches/live.patch
+       patch -p 0 < Patches/livedotcom-win32.patch
+       patch -p 0 < Patches/livedotcom-osx.patch
 
 .live: live
-       (cd $<; ./genMakefiles macosx-before-version-10.4-before-version-10.4 && make )
+ifeq ($(HOST),ppc-darwin)
+       (cd $<; ./genMakefiles macosx-before-version-10.4 && make )
+else
+ifdef HAVE_WIN32
+       (cd $<;./genMakefiles mingw && make $(HOSTCC))
+else
+       (cd $<; ./genMakefiles macosx && make )
+endif
+endif
        touch $@
 
 CLEAN_FILE += .live
 CLEAN_PKG += live
-DISTCLEAN_PKG += live-$(LIVEDOTCOM_VERSION).tar.gz
+DISTCLEAN_PKG += live555-$(LIVEDOTCOM_VERSION).tar.gz
 
 # ***************************************************************************
 # goom
@@ -885,10 +1058,20 @@ goom$(GOOM2k4_VERSION).tar.gz:
 
 goom: goom$(GOOM2k4_VERSION).tar.gz
        $(EXTRACT_GZ)
+ifdef HAVE_DARWIN_OS
        patch -p 0 < Patches/goom.patch
+endif
+ifdef HAVE_WIN32
+       (cd $@; dos2unix configure.in)
+       patch -p 0 <Patches/goom2k4-0-win32.patch
+endif
 
 .goom2k4: goom
-       (cd $<; ./configure --prefix=$(PREFIX) --disable-shared --enable-static && make && make install )
+ifdef HAVE_DARWIN_OS
+       (cd $<; ./configure --prefix=$(PREFIX) --disable-shared --enable-static && make && make install)
+else
+       (cd $< && rm -f configure; autoconf configure.in > configure && $(HOSTCC) sh ./configure $(HOSTCONF) --prefix=$(PREFIX) --disable-shared --enable-static --disable-glibtest --disable-gtktest && make && make install)
+endif
        touch $@
 
 CLEAN_FILE += .goom2k4
@@ -906,7 +1089,11 @@ libcaca: libcaca-$(LIBCACA_VERSION).tar.gz
        $(EXTRACT_GZ)
 
 .caca: libcaca
-       (cd $<; ./configure --prefix=$(PREFIX) --disable-imlib2 --disable-doc && make && make install)
+ifdef HAVE_WIN32
+       (cd $<; $(HOSTCC) ./configure $(HOSTCONF) --prefix=$(PREFIX) --enable-win32 --disable-x11 --disable-imlib2 --disable-doc && make && make install)
+else
+       (cd $<; $(HOSTCC) ./configure $(HOSTCONF) --prefix=$(PREFIX) --disable-imlib2 --disable-doc && make && make install)
+endif
        touch $@
 
 CLEAN_FILE += .caca
@@ -923,7 +1110,7 @@ libdts-$(LIBDTS_VERSION).tar.gz:
 ifeq ($(HOST),i586-pc-beos)
 # libdts 0.0.2 doesn't compile on BeOS
 libdts:
-       svn co svn://svn.videolan.org/libdts/trunk libdts
+       $(SVN) co svn://svn.videolan.org/libdts/trunk libdts
        (cd $@; ./bootstrap)
 else
 libdts: libdts-$(LIBDTS_VERSION).tar.gz
@@ -931,7 +1118,7 @@ libdts: libdts-$(LIBDTS_VERSION).tar.gz
 endif
 
 .dts: libdts
-       (cd $<; ./configure --prefix=$(PREFIX) && make && make install)
+       (cd $<; $(HOSTCC) ./configure $(HOSTCONF) --prefix=$(PREFIX) && make && make install)
        touch $@
 
 CLEAN_FILE += .dts
@@ -945,20 +1132,28 @@ DISTCLEAN_PKG += libdts-$(LIBDTS_VERSION).tar.gz
 ifdef SVN
 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:
        $(WGET) $(X264_URL)
 
 x264: x264-$(X264_VERSION).tar.gz
        $(EXTRACT_GZ)
+ifdef HAVE_WIN32
+       (cd x264;patch -p 0 <../Patches/x264-20050624-win32.patch)
+else
        patch -p 0 < Patches/x264.patch
        rm x264/x264.c
 endif
+endif
 
 .x264: x264
-       (cd $<; ./configure --enable-pthread --prefix=$(PREFIX) && make && make install)
+       (cd $<; ./configure $(X264CONF) --prefix=$(PREFIX) && make && make install)
        touch $@
 
 CLEAN_FILE += .x264
@@ -976,7 +1171,7 @@ libmodplug: libmodplug-$(MODPLUG_VERSION).tar.gz
        $(EXTRACT_GZ)
 
 .mod: libmodplug
-       (cd $<; ./configure --prefix=$(PREFIX) --disable-shared --enable-static && make && make install)
+       (cd $<; $(HOSTCC) ./configure $(HOSTCONF) --prefix=$(PREFIX) --disable-shared --enable-static && make && make install)
        touch $@
 
 CLEAN_FILE += .mod
@@ -995,12 +1190,12 @@ libcddb: libcddb-$(CDDB_VERSION).tar.gz
        patch -p 0 < Patches/libcddb.patch
 
 .cddb: libcddb
-       (cd $<; ./configure --prefix=$(PREFIX) --disable-shared --enable-static CFLAGS="$(CFLAGS) -D_BSD_SOCKLEN_T_=int" LDFLAGS="$(LDFLAGS) -liconv" && make && make install)
+       (cd $<; $(HOSTCC) ./configure $(HOSTCONF) --prefix=$(PREFIX) --disable-shared --enable-static CFLAGS="$(CFLAGS) -D_BSD_SOCKLEN_T_=int" LDFLAGS="$(LDFLAGS) -liconv" && make && make install)
        touch $@
 
 CLEAN_FILE += .cddb
 CLEAN_PKG += libcddb
-DISTCLEAN_PKG += libcddb-$(CDDB_VERSION).tar.gz
+DISTCLEAN_PKG += libcddb-$(CDDB_VERSION).tar.bz2
 
 # ***************************************************************************
 # vcdimager
@@ -1062,6 +1257,96 @@ CLEAN_FILE += .mash
 CLEAN_PKG += mash-code
 DISTCLEAN_PKG += mash-src-$(MASH_VERSION).tar.gz
 
+# ***************************************************************************
+# wxWidgets
+# ***************************************************************************
+
+wxWidgets-$(WXWIDGETS_VERSION).tar.gz:
+       $(WGET) $(WXWIDGETS_URL)
+
+wxwidgets: wxWidgets-$(WXWIDGETS_VERSION).tar.gz
+       $(EXTRACT_GZ)
+#      (cd wxwidgets; patch -p1 <../Patches/wxMSW-win32.patch)
+
+.wxwidgets: wxwidgets
+       (cd wxwidgets; $(HOSTCC) ./configure $(HOSTCONF) --prefix=$(PREFIX) --enable-optimise --disable-debug --disable-threads --disable-gif --disable-pcx --disable-iff --disable-pnm --without-zlib  --without-libpng --without-libjpeg --without-libtiff --without-regex  --disable-zipstream --disable-fs_zip --enable-no_rtti  --enable-no_exceptions --disable-exceptions --disable-stl --disable-html --without-expat --disable-protocols --disable-protocol --disable-xrc --disable-sound --disable-dialupman --disable-mediactrl  --disable-joystick --disable-grid --disable-datepick --disable-postscript--disable-filesystem --disable-fileproto --disable-ipc --disable-sockets --disable-precomp-headers && make && make install)
+       $(INSTALL_NAME)
+       touch $@
+
+CLEAN_FILE += .wxwidgets
+CLEAN_PKG += wxwidgets
+DISTCLEAN_PKG += wxWidgets-$(WXWIDGETS_VERSION).tar.gz
+
+# ***************************************************************************
+# zlib
+# ***************************************************************************
+
+zlib-$(ZLIB_VERSION).tar.gz:
+       $(WGET) $(ZLIB_URL)
+
+zlib: zlib-$(ZLIB_VERSION).tar.gz
+       $(EXTRACT_GZ)
+       patch -p 0 < Patches/zlib.patch
+
+.zlib: zlib
+       (cd zlib; $(HOSTCC2) ./configure  --prefix=$(PREFIX) && make install)
+       $(INSTALL_NAME)
+       touch $@
+
+CLEAN_FILE += .zlib
+CLEAN_PKG += zlib
+DISTCLEAN_PKG += zlib-$(ZLIB_VERSION).tar.gz
+
+
+# ***************************************************************************
+# PortAudio 
+# ***************************************************************************
+
+pa_snapshot_v$(PORTAUDIO_VERSION).tar.gz:
+       $(WGET) $(PORTAUDIO_URL)
+
+portaudio: pa_snapshot_v$(PORTAUDIO_VERSION).tar.gz
+       $(EXTRACT_GZ)
+ifneq ($(HOST),$(BUILD))
+       (patch -p 0 < Patches/portaudio-cross.patch;cd $@;  autoconf)
+endif
+
+.portaudio: portaudio 
+       (cd $<; $(HOSTCC) ./configure $(HOSTCONF) --prefix=$(PREFIX) && make && make  install)
+       $(INSTALL_NAME)
+       touch $@
+
+CLEAN_FILE += .portaudio
+CLEAN_PKG += portaudio
+DISTCLEAN_PKG += pa_snapshot_v$(PORTAUDIO__VERSION).tar.gz
+
+
+# ***************************************************************************
+# xml
+# ***************************************************************************
+
+libxml2-$(XML_VERSION).tar.gz:
+       $(WGET) $(XML_URL)
+
+xml: libxml2-$(XML_VERSION).tar.gz
+       $(EXTRACT_GZ)
+ifdef HAVE_WIN32
+       patch -p 0 < Patches/xml2-win32.patch
+       rm -f xml/aclocal.m4
+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)
+ifndef HAVE_DARWIN_OS
+       $(INSTALL_NAME)
+endif
+       touch $@
+
+CLEAN_FILE += .xml
+CLEAN_PKG += xml
+DISTCLEAN_PKG += libxml2-$(XML_VERSION).tar.gz
+
+
 # ***************************************************************************
 # twolame
 # ***************************************************************************
@@ -1073,7 +1358,7 @@ twolame: twolame-$(TWOLAME_VERSION).tar.gz
        $(EXTRACT_GZ)
 
 .twolame: twolame
-       (cd twolame; ./configure $(HOSTCONF) --prefix=$(PREFIX) && make && make install)
+       (cd twolame; $(HOSTCC) ./configure $(HOSTCONF) --prefix=$(PREFIX) && make && make install)
        $(INSTALL_NAME)
        touch $@
 
@@ -1091,9 +1376,20 @@ libpng-$(PNG_VERSION).tar.bz2:
 libpng: libpng-$(PNG_VERSION).tar.bz2
        $(EXTRACT_BZ2)
        cat Patches/libpng.patch | sed s,PREFIX,$(PREFIX), | patch -p0
-
-.png: libpng
+ifdef HAVE_WIN32
+       (cd $@; cat ../Patches/libpng-1.2.5-win32.patch | sed s,££PREFIX££,$(PREFIX), | patch -p0)
+endif
+.png: libpng 
+ifdef HAVE_DARWIN_OS
        (cd $<; cp scripts/makefile.macosx Makefile && make && make install)
+else
+ifdef HAVE_WIN32
+       (cd $<; rm -f INSTALL; cp scripts/makefile.cygwin Makefile && make $(HOSTCC) && make install-static)
+else
+       (cd $<; $(HOSTCC) ./configure $(HOSTCONF) --prefix=$(PREFIX) && make && make install)
+endif
+       $(INSTALL_NAME)
+endif 
        touch $@
 
 CLEAN_FILE += .png
@@ -1129,7 +1425,7 @@ libgpg-error: libgpg-error-$(GPGERROR_VERSION).tar.gz
        $(EXTRACT_GZ)
 
 .gpg-error: libgpg-error
-       (cd $<; ./configure --prefix=$(PREFIX) --disable-nls && make && make install)
+       (cd $<; $(HOSTCC) ./configure $(HOSTCONF) --prefix=$(PREFIX) --disable-nls && make && make install)
        $(INSTALL_NAME)
        touch $@
 
@@ -1141,21 +1437,25 @@ DISTCLEAN_PKG += libgpg-error-$(GPGERROR_VERSION).tar.gz
 # libgcrypt
 # ***************************************************************************
 
-libgcrypt-$(GCRYPT_VERSION).tar.gz:
+libgcrypt-$(GCRYPT_VERSION).tar.bz2:
        $(WGET) $(GCRYPT_URL)
 
-libgcrypt: libgcrypt-$(GCRYPT_VERSION).tar.gz
-       $(EXTRACT_GZ)
+libgcrypt: libgcrypt-$(GCRYPT_VERSION).tar.bz2
+       $(EXTRACT_BZ2)
        patch -p 0 < Patches/gcrypt.patch
 
 .gcrypt: libgcrypt .gpg-error
-       (cd $<; ./configure --prefix=$(PREFIX) CFLAGS="$(CFLAGS) -D_BSD_SOCKLEN_T_=int" && make && make install)
+ifdef HAVE_WIN32
+       (cd $<; $(HOSTCC) ./configure $(HOSTCONF) --target=i586-mingw32msvc --prefix=$(PREFIX) CFLAGS="$(CFLAGS)" && make && make install)
+else
+       (cd $<; $(HOSTCC) ./configure $(HOSTCONF) --prefix=$(PREFIX) CFLAGS="$(CFLAGS)" && make && make install)
+endif
        $(INSTALL_NAME)
        touch $@
 
 CLEAN_FILE += .gcrypt
 CLEAN_PKG += libgcrypt
-DISTCLEAN_PKG += libgcrypt-$(GCRYPT_VERSION).tar.gz
+DISTCLEAN_PKG += libgcrypt-$(GCRYPT_VERSION).tar.bz2
 
 # ***************************************************************************
 # gnutls
@@ -1166,9 +1466,14 @@ gnutls-$(GNUTLS_VERSION).tar.bz2:
 
 gnutls: gnutls-$(GNUTLS_VERSION).tar.bz2
        $(EXTRACT_BZ2)
+       (cd gnutls/gl ;ln -s alloca_.h alloca.h)
 
 .gnutls: gnutls .gcrypt .gpg-error
-       (cd $<; ./configure --prefix=$(PREFIX) && make && make install)
+ifdef HAVE_WIN32
+       (cd $<; $(HOSTCC) ./configure $(HOSTCONF) --prefix=$(PREFIX) CFLAGS="$(CFLAGS)" --target=i586-mingw32msvc && cd crypto && make && 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)
+endif
        $(INSTALL_NAME)
        touch $@
 
@@ -1187,11 +1492,12 @@ libopendaap: libopendaap-$(DAAP_VERSION).tar.bz2
        $(EXTRACT_BZ2)
        patch -p 0 < Patches/daap.patch
 
-.daap: libopendaap
+.opendaap: libopendaap
        (cd $<; ./configure --prefix=$(PREFIX) CFLAGS="$(CFLAGS) -D_BSD_SOCKLEN_T_=int" && make install)
+       $(INSTALL_NAME)
        touch $@
 
-CLEAN_FILE += .daap
+CLEAN_FILE += .opendaap
 CLEAN_PKG += libopendaap
 DISTCLEAN_PKG += libopendaap-$(DAAP_VERSION).tar.bz2
 
@@ -1231,6 +1537,55 @@ CLEAN_FILE += .libidl
 CLEAN_PKG += libIDL
 DISTCLEAN_PKG += libIDL-$(LIBIDL_VERSION).tar.gz
 
+# ***************************************************************************
+# Gecko SDK
+# ***************************************************************************
+
+gecko-sdk-ppc-macosx10.2-1.7.5.tar.gz:
+       $(WGET) $(GECKO_SDK_MAC_URL)
+
+gecko-sdk: gecko-sdk-ppc-macosx10.2-1.7.5.tar.gz
+       $(EXTRACT_GZ)
+
+.gecko: gecko-sdk
+       (cd $<)
+       touch $@
+
+CLEAN_FILE += .gecko
+CLEAN_PKG += gecko-sdk
+DISTCLEAN_PKG += gecko-sdk-ppc-macosx10.2-1.7.5.tar.gz
+
+# ***************************************************************************
+# Gecko SDK win32
+# ***************************************************************************
+
+gecko-sdk-i586-pc-msvc-1.7.5.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)
+
+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
+       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
+       touch $@
+
+CLEAN_FILE += .gecko-win32
+CLEAN_PKG += gecko-sdk-win32
+DISTCLEAN_PKG += gecko-sdk-i586-pc-msvc-1.7.5.zip libIDL-0.6.3-win32-bin.zip vc71-glib-1.2.10-bin.zip
+
 # ***************************************************************************
 # mozilla
 # ***************************************************************************
@@ -1260,7 +1615,7 @@ jpeg: jpeg-$(JPEG_VERSION).tar.gz
        $(EXTRACT_GZ)
 
 .jpeg: jpeg
-       (cd $<; ./configure --prefix=$(PREFIX) CFLAGS="$(CFLAGS)" && make && make install-lib)
+       (cd $<; $(HOSTCC) ./configure $(HOSTCONF) --prefix=$(PREFIX) CFLAGS="$(CFLAGS)" $(HOSTCC) && make && make install-lib)
        $(RANLIB) $(PREFIX)/lib/libjpeg.a
        touch $@
 
@@ -1279,9 +1634,16 @@ 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)
+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)
+endif
        touch $@
 
 CLEAN_FILE += .tiff
@@ -1300,7 +1662,7 @@ SDL: SDL-$(SDL_VERSION).tar.gz
        patch -p 0 < Patches/SDL.patch
 
 .SDL: SDL
-       (cd $<; ./configure --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 --disable-joystick --disable-cdrom --disable-threads --disable-sdl-dlopen CFLAGS="$(CFLAGS)" && make && make install)
        $(INSTALL_NAME)
        touch $@
 
@@ -1320,7 +1682,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 $<; ./configure --prefix=$(PREFIX) --enable-tif CFLAGS="$(CFLAGS)" && make && make install)
+       (cd $<; $(HOSTCC) ./configure $(HOSTCONF) --prefix=$(PREFIX) --enable-tif CFLAGS="$(CFLAGS)" && make && make install)
        $(INSTALL_NAME)
        touch $@
 
@@ -1328,6 +1690,122 @@ CLEAN_FILE += .SDL_image
 CLEAN_PKG += SDL_image
 DISTCLEAN_PKG += SDL_image-$(SDL_IMAGE_VERSION).tar.gz
 
+# ***************************************************************************
+# Musepack decoder library (libmpcdec)
+# ***************************************************************************
+
+libmpcdec-$(MUSE_VERSION).tar.bz2:
+       $(WGET) $(MUSE_URL)
+
+mpcdec: libmpcdec-$(MUSE_VERSION).tar.bz2 
+       $(EXTRACT_BZ2)
+       patch -p 0 < Patches/mpcdec.patch
+ifdef HAVE_WIN32
+       (cd $@; ./autogen.sh)
+endif
+
+.mpcdec: mpcdec
+ifdef HAVE_WIN32 
+       (cd $<; $(HOSTCC) ./configure $(HOSTCONF) --prefix=$(PREFIX) CFLAGS=-D_PTRDIFF_T=mpc_int32_t && make && make install)
+else
+       (cd $<; $(HOSTCC) ./configure $(HOSTCONF) --prefix=$(PREFIX) && make && make install)
+endif
+ifdef HAVE_DARWIN_OS
+       $(INSTALL_NAME)
+endif
+       touch $@
+
+CLEAN_FILE += .mpcdec
+CLEAN_PKG += mpcdec
+DISTCLEAN_PKG += libmpcdec-$(MUSE_VERSION).tar.bz2
+
+# ***************************************************************************
+# Dirac
+# ***************************************************************************
+
+dirac-$(DIRAC_VERSION).tar.gz:
+       $(WGET) $(DIRAC_URL)
+
+dirac: dirac-$(DIRAC_VERSION).tar.gz
+       $(EXTRACT_GZ)
+ifneq ($(HOST),$(BUILD))
+       patch -p 0 <Patches/dirac-cross.patch
+       (cd $@; aclocal && autoconf && automake)
+endif
+
+.dirac: dirac
+       (cd $<; $(HOSTCC) ./configure $(HOSTCONF) --prefix=$(PREFIX)  CFLAGS="$(CFLAGS)" && DOC_DIR="" make && DOC_DIR="" make install)
+       $(INSTALL_NAME)
+       touch $@
+
+CLEAN_FILE += .dirac
+CLEAN_PKG += dirac
+DISTCLEAN_PKG += dirac-$(DIRAC_VERSION).tar.gz
+
+# *************************************************************************
+# DirectX headers
+# *************************************************************************
+win32-dx7headers.tgz:
+       $(WGET) $(DX_HEADERS_URL)
+.dx_headers: win32-dx7headers.tgz
+       (cd ../include ; tar xzf ../src/$<)
+       touch $@
+CLEAN_FILE += .dx_headers
+DISTCLEAN_PKG += win32-dx7headers.tgz
+# *************************************************************************
+# DirectShow headers
+# *************************************************************************
+dshow-headers.tgz:
+       $(WGET) $(DSHOW_HEADERS_URL)
+.dshow_headers: dshow-headers.tgz
+       (cd ../include ; tar xzf ../src/$<)
+       touch $@
+CLEAN_FILE += .dshow_headers
+DISTCLEAN_PKG += dshow-headers.tgz
+
+# ***************************************************************************
+# libexpat
+# ***************************************************************************
+
+expat-$(EXPAT_VERSION).tar.gz:
+       $(WGET) $(EXPAT_URL)
+
+expat: expat-$(EXPAT_VERSION).tar.gz
+       $(EXTRACT_GZ)
+
+.expat: expat
+       (cd $<; ./configure --prefix=$(PREFIX) && make && make install)
+       touch $@
+
+CLEAN_FILE += .expat
+CLEAN_PKG += expat
+DISTCLEAN_PKG += expat-$(EXPAT_VERSION).tar.gz
+
+# ***************************************************************************
+# CyberLink C++ UPnP library
+# ***************************************************************************
+
+clinkcc$(CLINKCC_VERSION).tar.gz:
+       $(WGET) $(CLINKCC_URL)
+
+clinkcc: clinkcc$(CLINKCC_VERSION).tar.gz
+       tar xzf $<
+       mv $(patsubst %.tar.gz,Cyberlink,$(patsubst %.tgz,Cyberlink,$(notdir $<))) $@ || true
+       touch $@
+       patch -p 0 < Patches/clinkcc.patch
+ifdef HAVE_DARWIN_OS
+       patch -p 0 < Patches/clinkcc_osx.patch
+endif
+
+.clinkcc: clinkcc
+       (cd $<; ./bootstrap && ./configure --prefix=$(PREFIX) --enable-expat && make && chmod 755 config/install-sh && make install )
+       touch $@
+
+CLEAN_FILE += .clinkcc
+CLEAN_PKG += clinkcc
+DISTCLEAN_PKG += clinkcc-$(CLINKCC_VERSION).tar.gz
+
 # ***************************************************************************
 # Copy aclocal files
 # This is necessary for --missing aclocal to succeed after a
@@ -1338,6 +1816,7 @@ DISTCLEAN_PKG += SDL_image-$(SDL_IMAGE_VERSION).tar.gz
        cp -R $(PREFIX)/share/aclocal/* $(PREFIX)/../../m4/
        touch $@
 
+CLEAN_FILE += .aclocal
 
 # ***************************************************************************
 # Some cleansing