]> 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 d55acafca93b8cbc1b4c908a5a0b299fe700db33..068fa4c2f9958caefb08917d2c7d40d343f8ba99 100644 (file)
@@ -23,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
@@ -65,9 +65,16 @@ 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))
@@ -75,6 +82,10 @@ ifneq ($(BUILD),$(HOST))
 HOSTCONF=--host=$(HOST) --build=$(BUILD)
 FFMPEGCONF=--cross-prefix=$(HOST)-
 X264CONF=--crosscompile=$(HOST)
+else
+   ifneq ($(CC),)
+      FFMPEGCONF=--cc="$(CC)"
+   endif
 endif
 
 #
@@ -82,12 +93,12 @@ endif
 #
 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
+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-protocols
+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
@@ -96,18 +107,25 @@ ifdef HAVE_BEOS
 FFMPEGCONF+= --cpu=x86
 endif
 
+ifeq ($(HOST),i686-apple-darwin8)
+FFMPEGCONF += --enable-memalign-hack
+endif
+
 # ***************************************************************************
 # Standard rules
 # ***************************************************************************
 
 ifdef HAVE_DARWIN_OS
  all: .autoconf .automake .libtool .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 \
+       .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 .libmpcdec .expat .clinkcc .aclocal
+       .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
 
  ifdef HAVE_BEOS
@@ -116,14 +134,14 @@ 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 \
-       .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
 
@@ -133,15 +151,15 @@ else
        .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 .libmpcdec \
-       .gnutls .dvdread .dvdnav .dvbpsi .wxwidgets .dirac \
+       .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
+#      .SDL_image  .daap .cddb .cdio .vcdimager .dts .portaudio 
   else
 
    ifdef HAVE_WINCE
 
-   all: .dvbpsi .zlib .ffmpeg .ogg .tremor
+   all: .dvbpsi .zlib .ffmpeg .ogg .tremor .faad
    else
 
 # Standard Linux or other UNIX-like systems
@@ -149,8 +167,8 @@ else
        .a52 .mpeg2 .id3tag .mad .ogg .vorbis .vorbisenc .theora \
        .FLAC .speex .faad .faac .lame .ebml .dts .matroska .ffmpeg .dvdcss \
        .live .goom2k4 .caca .mod .x264  .xml .twolame\
-       .png .gpg-error .gcrypt .gnutls .libmpcdec\
-       .gnutls .dvdread .dvdnav .dvbpsi .wxwidgets .dirac \
+       .png .gpg-error .gcrypt .gnutls .mpcdec\
+       .gnutls .dvdnav .dvbpsi .wxwidgets .dirac \
        .aclocal 
 #      .SDL_image  .daap .cddb .cdio .vcdimager 
    endif
@@ -269,6 +287,7 @@ 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 \
@@ -432,7 +451,7 @@ ifdef HAVE_WIN32
        patch -p 0 <Patches/fribidi-win32.patch
 endif
 .fribidi: fribidi .iconv
-       (cd $<; ./bootstrap && $(HOSTCC) ./configure $(HOSTCONF) --prefix=$(PREFIX)  && make && make install)
+       (cd $<; rm -f configure; ./bootstrap && $(HOSTCC) ./configure $(HOSTCONF) --prefix=$(PREFIX)  && make && make install)
        $(INSTALL_NAME)
        touch $@
 
@@ -662,6 +681,9 @@ 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
@@ -715,12 +737,11 @@ faad2-$(FAAD2_VERSION).tar.bz2:
 
 faad2: faad2-$(FAAD2_VERSION).tar.bz2
        $(EXTRACT_BZ2)
-ifdef HAVE_WIN32
-       (cd faad2;patch -p 0  < ../Patches/faad2-20050513-win32.patch && ./bootstrap)
-endif
+       (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
+ifndef HAVE_DARWIN_OS
        $(INSTALL_NAME)
 endif
        touch $@
@@ -817,7 +838,7 @@ endif
 
 .matroska: libmatroska .ebml
 ifdef HAVE_WIN32
-       (cd $<; make -C make/mingw32 prefix=$(PREFIX) $(HOSTCC2) CPPFLAGS=$(CFLAGS) libmatroska.a && make -C make/linux install_staticlib install_headers prefix=$(PREFIX) $(HOSTCC2))
+       (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
@@ -842,6 +863,7 @@ ifeq ($(HOST),i586-pc-beos)
 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
@@ -849,6 +871,9 @@ 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)
@@ -869,25 +894,6 @@ 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 $<; $(HOSTCC) ./configure $(HOSTCONF) --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
 # ***************************************************************************
@@ -914,32 +920,41 @@ CLEAN_PKG += libdvdcss
 DISTCLEAN_PKG += libdvdcss-$(LIBDVDCSS_VERSION).tar.gz
 
 # ***************************************************************************
-# libdvdread
+# libdvdread: We use dvdnav's dvdread
 # ***************************************************************************
 
-libdvdread-$(LIBDVDREAD_VERSION).tar.bz2:
-       $(WGET) $(LIBDVDREAD_URL)
+#libdvdread-$(LIBDVDREAD_VERSION).tar.bz2:
+#      $(WGET) $(LIBDVDREAD_URL)
 
-libdvdread: libdvdread-$(LIBDVDREAD_VERSION).tar.bz2
-       $(EXTRACT_BZ2)
-       patch  -p 0 < Patches/libdvdread.patch
-ifdef HAVE_WIN32
+#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
+#      (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)
+#.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
+
+# ***************************************************************************
+# 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.bz2
 
 # ***************************************************************************
 # libdvdnav
@@ -950,16 +965,13 @@ libdvdnav-$(LIBDVDNAV_VERSION).tar.bz2:
 
 libdvdnav: libdvdnav-$(LIBDVDNAV_VERSION).tar.bz2
        $(EXTRACT_BZ2)
-ifdef HAVE_WIN32
-       (cd $@; patch -p 0 < ../Patches/libdvdnav-20050211-win32.patch)
-else
        patch -p 0 < Patches/dvdnav.patch
-endif
+       patch -p 0 < Patches/libdvdnav-mactel.patch
        (cd $@; ./autogen.sh noconfig)
 
-.dvdnav: libdvdnav .dvdread
+.dvdnav: libdvdnav .dvdcss
 ifdef HAVE_WIN32       
-       (cd $<; $(HOSTCC) ./configure $(HOSTCONF) --enable-static --prefix=$(PREFIX) --with-libdvdcss=$(PREFIX) --disable-builtin-dvdread CFLAGS="$(CFLAGS)" CPPFLAGS="$(CPPFLAGS) -DNDEBUG -Dssize_t=long" && make  && make install)
+       (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
@@ -1050,6 +1062,7 @@ 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
 
@@ -1057,7 +1070,7 @@ endif
 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) ./configure $(HOSTCONF) --prefix=$(PREFIX) --disable-shared --enable-static --disable-glibtest --disable-gtktest && make && make install)
+       (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 $@
 
@@ -1076,7 +1089,11 @@ libcaca: libcaca-$(LIBCACA_VERSION).tar.gz
        $(EXTRACT_GZ)
 
 .caca: libcaca
+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
@@ -1093,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
@@ -1116,9 +1133,9 @@ 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 )
+       (cd x264; patch -p 0 < ../Patches/x264-svn-win32.patch )
 else
-       cd x264 && patch -p 0 < ../Patches/x264_svn.patch
+       patch -p 0 < Patches/x264_svn.patch
        rm x264/x264.c
 endif
 else
@@ -1252,7 +1269,7 @@ wxwidgets: wxWidgets-$(WXWIDGETS_VERSION).tar.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  && make && make install)
+       (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 $@
 
@@ -1290,6 +1307,9 @@ pa_snapshot_v$(PORTAUDIO_VERSION).tar.gz:
 
 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)
@@ -1364,7 +1384,7 @@ 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)
+       (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
@@ -1422,7 +1442,7 @@ libgcrypt-$(GCRYPT_VERSION).tar.bz2:
 
 libgcrypt: libgcrypt-$(GCRYPT_VERSION).tar.bz2
        $(EXTRACT_BZ2)
-#      patch -p 0 < Patches/gcrypt.patch
+       patch -p 0 < Patches/gcrypt.patch
 
 .gcrypt: libgcrypt .gpg-error
 ifdef HAVE_WIN32
@@ -1677,23 +1697,26 @@ DISTCLEAN_PKG += SDL_image-$(SDL_IMAGE_VERSION).tar.gz
 libmpcdec-$(MUSE_VERSION).tar.bz2:
        $(WGET) $(MUSE_URL)
 
-libmpcdec: libmpcdec-$(MUSE_VERSION).tar.bz2 
+mpcdec: libmpcdec-$(MUSE_VERSION).tar.bz2 
        $(EXTRACT_BZ2)
-       patch -p 0 < Patches/libmpcdec.patch
+       patch -p 0 < Patches/mpcdec.patch
 ifdef HAVE_WIN32
        (cd $@; ./autogen.sh)
 endif
 
-.libmpcdec: libmpcdec
+.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 += .libmpcdec
-CLEAN_PKG += libmpcdec
+CLEAN_FILE += .mpcdec
+CLEAN_PKG += mpcdec
 DISTCLEAN_PKG += libmpcdec-$(MUSE_VERSION).tar.bz2
 
 # ***************************************************************************