]> git.sesse.net Git - vlc/blobdiff - extras/contrib/Makefile
contribs: updated binary package for Mac OS X (i686 and x86_64 only for now)
[vlc] / extras / contrib / Makefile
index 12e2a6f8c36ac0149f270fcdc3dbd1f0a0181d8b..87403374d1918801391bbd197000a24af35f4c51 100644 (file)
 #
 # 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
 
-BUILDDIRS = bin doc etc include info lib man sbin share vlc-lib tmp
-
-all: FORCE
-#      @echo "Do you mean to make src or make bin ?"
-       @echo "    'make bin' isn't functional at the moment,"
-       @echo "    running 'make src' instead..."
-       $(MAKE) src
-
-src: FORCE
-       $(MAKE) -C src all
-
-contrib-macosx.tar.bz2: FORCE
-       $(WGET) $(CONTRIB_URL)
-
-bin: FORCE
-       @echo "make bin isn't in a functional state at this moment. Please use make src"
-
-#The disabled make bin
-#bin: contrib-macosx.tar.bz2
-#      @if test -d tmp; then \
-#              echo "Move away ./tmp, it's in the way" ; \
-#              exit 1 ; \
-#      fi
-#      mkdir tmp
-#      bunzip2 -c $< | (cd tmp; tar xf -)
-#      ./change_prefix.sh tmp @@CONTRIB_PREFIX@@ $(PREFIX)
-#      (cd tmp; tar cf - .) | tar xf -
-#      rm -rf tmp
-#      ranlib lib/*\.a
-
-clean-src: FORCE
+BUILDDIRS = bin doc etc include info lib man sbin share tmp gecko-sdk
+
+ifdef HAVE_DARWIN_OS
+TARGETALL=using-bin
+else
+TARGETALL=using-src
+endif
+
+all: $(TARGETALL)
+
+using-src:
+       $(MAKE) -C src
+
+# shortcut
+src: using-src
+
+ifdef HAVE_DARWIN_OS
+
+ifdef HAVE_DARWIN_OS_ON_INTEL
+CONTRIBREV=6
+else
+CONTRIBREV=5
+endif
+contrib-macosx-$(ARCH)-$(CONTRIBREV).tar.bz2:
+       $(WGET) ftp://ftp.videolan.org/pub/videolan/testing/contrib/$@
+
+using-bin: contrib-macosx-$(ARCH)-$(CONTRIBREV).tar.bz2
+       @if test -d tmp; then \
+               echo "Move away ./tmp, it's in the way" ; \
+               exit 1 ; \
+       fi
+       mkdir tmp
+       (cd tmp && tar jxvf ../$<)
+       ./change_prefix.sh tmp @@CONTRIB_PREFIX@@  $(PREFIX)
+       for dir in `(cd tmp && find . -type d)`; do mkdir -p -- $$dir; done
+       for i in `(cd tmp && find . -not -type d)`; do mv -f tmp/$$i $$i; done
+       rm -rf tmp
+endif
+
+clean-src:
        rm -rf $(BUILDDIRS)
        $(MAKE) -C src clean-src
 
-clean-bin: FORCE
+clean-bin:
        rm -rf $(BUILDDIRS)
        $(MAKE) -C src clean-dots
 
-clean: FORCE
-#      @echo "    Do you mean to clean-src or clean-bin ?"
-       @echo "    'make bin' isn't available at the moment"
-       @echo "    you probably wanna run 'make clean-src' then"
-       @echo "    you can still run 'make clean-bin' manually if needed"
+clean:
        $(MAKE) clean-src
+       rm -rf config.mak distro.mak
+
+bin: using-bin
 
-package-macosx: FORCE
+package-macosx:
        @if test -d tmp; then \
                echo "Move away ./tmp, it's in the way" ; \
                exit 1 ; \
        fi
        mkdir tmp
-       tar cf - bin sbin include lib vlc-lib share/aclocal* share/autoconf* \
-               share/automake* share/gettext* \
+       tar cf - bin sbin include lib share/aclocal* share/autoconf* \
+               share/automake* share/gettext* share/libtool* gecko-sdk \
                | (cd tmp; tar xf -)
        ./change_prefix.sh tmp $(PREFIX) @@CONTRIB_PREFIX@@
        (cd tmp; tar cf - .) | bzip2 -c > contrib-macosx.tar.bz2
        rm -rf tmp
 
-package-win32: FORCE
+DISTDIR = usr/win32
+
+package-win32:
        @if test -d tmp; then \
                echo "Move away ./tmp, it's in the way" ; \
                exit 1 ; \
        fi
-       mkdir -p tmp/usr/win32
-       tar cf - bin sbin include lib share/aclocal* share/autoconf* \
+       mkdir -p tmp/$(DISTDIR)
+       tar cf - --dereference bin sbin include lib share/aclocal*\
+               share/autoconf* share/qt4* \
                share/automake* share/gettext* gecko-sdk\
-               | (cd tmp/usr/win32; tar xf -)
+               | (cd tmp/$(DISTDIR); tar xpf -)
 #kludge for live.com
-       mkdir -p tmp/usr/win32/live.com
+       mkdir -p tmp/$(DISTDIR)/live.com
        for i in groupsock liveMedia UsageEnvironment BasicUsageEnvironment; do \
-               mkdir -p  tmp/usr/win32/live.com/$$i/include; \
-               cp -r src/live/$$i/include tmp/usr/win32/live.com/$$i/include; \
-               cp src/live/$$i/lib$${i}.a  tmp/usr/win32/live.com/$$i; \
+               mkdir -p  tmp/$(DISTDIR)/live.com/$$i/include; \
+               cp -r src/live/$$i/include tmp/$(DISTDIR)/live.com/$$i; \
+               cp src/live/$$i/lib$${i}.a  tmp/$(DISTDIR)/live.com/$$i; \
        done;
-       ./change_prefix.sh tmp $(PREFIX) /usr/win32
-       (cd tmp; tar cf - usr/win32/) | bzip2 -c > contrib-`date +%Y%m%d`-win32-bin-gcc-`$(CC) --version|head -n 1|cut -f 3 -d ' '`-only.tar.bz2
+# Change Prefix.
+       ./change_prefix.sh tmp $(PREFIX) $(DISTDIR)
+# Hack for qt4
+       (cd tmp/$(DISTDIR)/bin; mv uic.exe uic.ex; mv rcc.exe rcc.ex; mv moc.exe moc.ex)
+#      Remove unused and potentially harmful files     
+       (cd tmp/$(DISTDIR)/bin; rm -rfv *.exe; chmod a+x *)
+# Hack for qt4
+       (cd tmp/$(DISTDIR)/bin; mv uic.ex uic.exe; mv rcc.ex rcc.exe; mv moc.ex moc.exe)
+# Tar it.
+       (cd tmp; tar cf - $(DISTDIR)) | bzip2 -c > contrib-`date +%Y%m%d`-win32-bin-gcc-`$(CC) --version|head -n 1|cut -f 3 -d ' '`-runtime-`/bin/echo -e "#include <_mingw.h>\n__MINGW32_VERSION"|$(CC) -E -|grep -v ^#|grep -v ' '`-only.tar.bz2
        rm -rf tmp
-FORCE:
+
+.PHONY: all clean-src clean-bin clean package-macosx package-win32