]> git.sesse.net Git - vlc/blobdiff - contrib/src/main.mak
contrib: fix libdsm and libtasn1 rules
[vlc] / contrib / src / main.mak
index 74da11fc915c5694992a7c2903058782c720c235..b42ea469fdd3ea1724aff6ce1e3f0014e09d9232 100644 (file)
@@ -5,9 +5,18 @@
 
 all: install
 
-ALL_PKGS := $(patsubst ../src/%/rules.mak,%,$(wildcard ../src/*/rules.mak))
-SRC := ../src
-TARBALLS := ../tarballs
+# bootstrap configuration
+include config.mak
+
+TOPSRC ?= ../../contrib
+TOPDST ?= ..
+SRC := $(TOPSRC)/src
+TARBALLS := $(TOPSRC)/tarballs
+
+PATH :=$(abspath ../../extras/tools/build/bin):$(PATH)
+export PATH
+
+PKGS_ALL := $(patsubst $(SRC)/%/rules.mak,%,$(wildcard $(SRC)/*/rules.mak))
 DATE := $(shell date +%Y%m%d)
 VPATH := $(TARBALLS)
 
@@ -15,24 +24,19 @@ VPATH := $(TARBALLS)
 GNU := http://ftp.gnu.org/gnu
 SF := http://heanet.dl.sourceforge.net/sourceforge
 VIDEOLAN := http://downloads.videolan.org/pub/videolan
-CONTRIB_VIDEOLAN := $(VIDEOLAN)/testing/contrib
-
-# bootstrap configuration
-include config.mak
+CONTRIB_VIDEOLAN := http://downloads.videolan.org/pub/contrib
 
 #
 # Machine-dependent variables
 #
-PREFIX ?= ../hosts/$(HOST)
+
+PREFIX ?= $(TOPDST)/$(HOST)
 PREFIX := $(abspath $(PREFIX))
 ifneq ($(HOST),$(BUILD))
 HAVE_CROSS_COMPILE = 1
 endif
 ARCH := $(shell $(SRC)/get-arch.sh $(HOST))
-ifneq ($(findstring $(ARCH),i386 sparc sparc64 ppc ppc64 x86_64),)
-# This should be consistent with include/vlc_cpu.h
-HAVE_FPU = 1
-endif
+
 ifeq ($(ARCH)-$(HAVE_WIN32),x86_64-1)
 HAVE_WIN64 := 1
 endif
@@ -86,14 +90,98 @@ STRIP := $(HOST)-strip
 endif
 endif
 
+ifdef HAVE_ANDROID
+CC :=  $(HOST)-gcc --sysroot=$(ANDROID_NDK)/platforms/$(ANDROID_API)/arch-$(PLATFORM_SHORT_ARCH)
+CXX := $(HOST)-g++ --sysroot=$(ANDROID_NDK)/platforms/$(ANDROID_API)/arch-$(PLATFORM_SHORT_ARCH)
+endif
+
+ifdef HAVE_MACOSX
+MIN_OSX_VERSION=10.6
+CC=xcrun cc
+CXX=xcrun c++
+AR=xcrun ar
+LD=xcrun ld
+STRIP=xcrun strip
+RANLIB=xcrun ranlib
+EXTRA_CFLAGS += -isysroot $(MACOSX_SDK) -mmacosx-version-min=$(MIN_OSX_VERSION) -DMACOSX_DEPLOYMENT_TARGET=$(MIN_OSX_VERSION)
+EXTRA_LDFLAGS += -Wl,-syslibroot,$(MACOSX_SDK) -mmacosx-version-min=$(MIN_OSX_VERSION) -isysroot $(MACOSX_SDK) -DMACOSX_DEPLOYMENT_TARGET=$(MIN_OSX_VERSION)
+ifeq ($(ARCH),x86_64)
+EXTRA_CFLAGS += -m64
+EXTRA_LDFLAGS += -m64
+else
+EXTRA_CFLAGS += -m32
+EXTRA_LDFLAGS += -m32
+endif
+
+XCODE_FLAGS = -sdk macosx$(OSX_VERSION)
+ifeq ($(shell xcodebuild -version 2>/dev/null | tee /dev/null|head -1|cut -d\  -f2|cut -d. -f1),3)
+XCODE_FLAGS += ARCHS=$(ARCH)
+# XCode 3 doesn't support -arch
+else
+XCODE_FLAGS += -arch $(ARCH)
+endif
+
+endif
+
+CCAS=$(CC) -c
+
+ifdef HAVE_IOS
+CC=xcrun clang
+CXX=xcrun clang++
+ifdef HAVE_NEON
+AS=perl $(abspath ../../extras/tools/build/bin/gas-preprocessor.pl) $(CC)
+CCAS=gas-preprocessor.pl $(CC) -c
+else
+CCAS=$(CC) -c
+endif
+AR=xcrun ar
+LD=xcrun ld
+STRIP=xcrun strip
+RANLIB=xcrun ranlib
+EXTRA_CFLAGS += $(CFLAGS)
+EXTRA_LDFLAGS += $(LDFLAGS)
+endif
+
+ifdef HAVE_WIN32
+ifneq ($(shell $(CC) $(CFLAGS) -E -dM -include _mingw.h - < /dev/null | grep -E __MINGW64_VERSION_MAJOR),)
+HAVE_MINGW_W64 := 1
+endif
+endif
+
+ifdef HAVE_SOLARIS
+ifeq ($(ARCH),x86_64)
+EXTRA_CFLAGS += -m64
+EXTRA_LDFLAGS += -m64
+else
+EXTRA_CFLAGS += -m32
+EXTRA_LDFLAGS += -m32
+endif
+endif
+
+cppcheck = $(shell $(CC) $(CFLAGS) -E -dM - < /dev/null | grep -E $(1))
+
 EXTRA_CFLAGS += -I$(PREFIX)/include
 CPPFLAGS := $(CPPFLAGS) $(EXTRA_CFLAGS)
-CFLAGS := $(CFLAGS) $(EXTRA_CFLAGS)
-CXXFLAGS := $(CXXFLAGS) $(EXTRA_CFLAGS)
+CFLAGS := $(CFLAGS) $(EXTRA_CFLAGS) -g
+CXXFLAGS := $(CXXFLAGS) $(EXTRA_CFLAGS) -g
 EXTRA_LDFLAGS += -L$(PREFIX)/lib
 LDFLAGS := $(LDFLAGS) $(EXTRA_LDFLAGS)
 # Do not export those! Use HOSTVARS.
 
+# Do the FPU detection, after we have figured out our compilers and flags.
+ifneq ($(findstring $(ARCH),aarch64 i386 ppc ppc64 sparc sparc64 x86_64),)
+# This should be consistent with include/vlc_cpu.h
+HAVE_FPU = 1
+else ifneq ($(findstring $(ARCH),arm),)
+ifneq ($(call cppcheck, __VFP_FP__)),)
+ifeq ($(call cppcheck, __SOFTFP__),)
+HAVE_FPU = 1
+endif
+endif
+else ifneq ($(call cppcheck, __mips_hard_float),)
+HAVE_FPU = 1
+endif
+
 ACLOCAL_AMFLAGS += -I$(PREFIX)/share/aclocal
 export ACLOCAL_AMFLAGS
 
@@ -101,8 +189,8 @@ PKG_CONFIG ?= pkg-config
 ifdef HAVE_CROSS_COMPILE
 # This inhibits .pc file from within the cross-compilation toolchain sysroot.
 # Hopefully, nobody ever needs that.
-PKG_CONFIG_PATH :=
-PKG_CONFIG_LIBDIR := /dev/null
+PKG_CONFIG_PATH := /usr/share/pkgconfig
+PKG_CONFIG_LIBDIR := /usr/$(HOST)/lib/pkgconfig
 export PKG_CONFIG_LIBDIR
 endif
 PKG_CONFIG_PATH := $(PKG_CONFIG_PATH):$(PREFIX)/lib/pkgconfig
@@ -122,94 +210,150 @@ endif
 endif
 SVN ?= $(error subversion client (svn) not found!)
 
-ifndef WGET
-ifeq ($(shell wget --version >/dev/null 2>&1 || echo FAIL),)
-WGET = wget --passive -c
+ifeq ($(shell curl --version >/dev/null 2>&1 || echo FAIL),)
+download = curl -f -L -- "$(1)" > "$@"
+else ifeq ($(shell wget --version >/dev/null 2>&1 || echo FAIL),)
+download = rm -f $@.tmp && \
+       wget --passive -c -p -O $@.tmp "$(1)" && \
+       touch $@.tmp && \
+       mv $@.tmp $@
+else ifeq ($(which fetch >/dev/null 2>&1 || echo FAIL),)
+download = rm -f $@.tmp && \
+       fetch -p -o $@.tmp "$(1)" && \
+       touch $@.tmp && \
+       mv $@.tmp $@
+else
+download = $(error Neither curl nor wget found!)
 endif
+
+ifeq ($(shell which bzcat >/dev/null 2>&1 || echo FAIL),)
+BZCAT = bzcat
+else
+BZCAT ?= $(error Bunzip2 client (bzcat) not found!)
 endif
-ifndef WGET
-ifeq ($(shell curl --version >/dev/null 2>&1 || echo FAIL),)
-WGET = curl -L -O
+
+ifeq ($(shell gzcat --version >/dev/null 2>&1 || echo FAIL),)
+ZCAT = gzcat
+else ifeq ($(shell zcat --version >/dev/null 2>&1 || echo FAIL),)
+ZCAT = zcat
+else
+ZCAT ?= $(error Gunzip client (zcat) not found!)
 endif
+
+ifeq ($(shell sha512sum --version >/dev/null 2>&1 || echo FAIL),)
+SHA512SUM = sha512sum --check
+else ifeq ($(shell shasum --version >/dev/null 2>&1 || echo FAIL),)
+SHA512SUM = shasum -a 512 --check
+else ifeq ($(shell openssl version >/dev/null 2>&1 || echo FAIL),)
+SHA512SUM = openssl dgst -sha512
+else
+SHA512SUM = $(error SHA-512 checksumming not found!)
 endif
-WGET ?= $(error Neither wget not curl found!)
 
 #
 # Common helpers
 #
-HOSTVARS := CPPFLAGS="$(CPPFLAGS)"
-HOSTVARS += CC="$(CC)"
-HOSTVARS += CFLAGS="$(CFLAGS)"
-HOSTVARS += CXX="$(CXX)"
-HOSTVARS += CXXFLAGS="$(CXXFLAGS)"
-HOSTVARS += LD="$(LD)"
-HOSTVARS += LDFLAGS="$(LDFLAGS)"
-HOSTVARS += AR="$(AR)"
-HOSTVARS += RANLIB="$(RANLIB)"
-HOSTVARS += STRIP="$(STRIP)"
-HOSTVARS_AR += AR="$(AR) rcvu"
-
 HOSTCONF := --prefix="$(PREFIX)"
+HOSTCONF += --datarootdir="$(PREFIX)/share"
+HOSTCONF += --includedir="$(PREFIX)/include"
+HOSTCONF += --libdir="$(PREFIX)/lib"
 HOSTCONF += --build="$(BUILD)" --host="$(HOST)" --target="$(HOST)"
 HOSTCONF += --program-prefix=""
 # libtool stuff:
 HOSTCONF += --enable-static --disable-shared --disable-dependency-tracking
 ifdef HAVE_WIN32
 HOSTCONF += --without-pic
+PIC :=
 else
 HOSTCONF += --with-pic
+PIC := -fPIC
 endif
 
-download = rm -f $@.tmp && \
-               $(WGET) -p -O $@.tmp $(1) && \
-               touch $@.tmp && \
-               mv $@.tmp $@
+HOSTTOOLS := \
+       CC="$(CC)" CXX="$(CXX)" LD="$(LD)" \
+       AR="$(AR)" CCAS="$(CCAS)" RANLIB="$(RANLIB)" STRIP="$(STRIP)" \
+       PATH="$(PREFIX)/bin:$(PATH)"
+HOSTVARS := $(HOSTTOOLS) \
+       CPPFLAGS="$(CPPFLAGS)" \
+       CFLAGS="$(CFLAGS)" \
+       CXXFLAGS="$(CXXFLAGS)" \
+       LDFLAGS="$(LDFLAGS)"
+HOSTVARS_PIC := $(HOSTTOOLS) \
+       CPPFLAGS="$(CPPFLAGS) $(PIC)" \
+       CFLAGS="$(CFLAGS) $(PIC)" \
+       CXXFLAGS="$(CXXFLAGS) $(PIC)" \
+       LDFLAGS="$(LDFLAGS)"
+
 download_git = \
        rm -Rf $(@:.tar.xz=) && \
        $(GIT) clone $(2:%=--branch %) $(1) $(@:.tar.xz=) && \
+       (cd $(@:.tar.xz=) && $(GIT) checkout $(3:%= %)) && \
        rm -Rf $(@:%.tar.xz=%)/.git && \
        (cd $(dir $@) && \
-        tar cvJ $(notdir $(@:.tar.xz=))) > $@ && \
+       tar cvJ $(notdir $(@:.tar.xz=))) > $@ && \
        rm -Rf $(@:.tar.xz=)
-checksum = (cd $(TARBALLS) && $(1)sum -c -) < \
-               $(SRC)/$(patsubst .sum-%,%,$@)/$(2)SUMS
-CHECK_SHA256 = $(call checksum,sha512,SHA512)
-CHECK_SHA512 = $(call checksum,sha512,SHA512)
+checksum = \
+       $(foreach f,$(filter $(TARBALLS)/%,$^), \
+               grep -- " $(f:$(TARBALLS)/%=%)$$" \
+                       "$(SRC)/$(patsubst .sum-%,%,$@)/$(2)SUMS" &&) \
+       (cd $(TARBALLS) && $(1) /dev/stdin) < \
+               "$(SRC)/$(patsubst .sum-%,%,$@)/$(2)SUMS"
+CHECK_SHA512 = $(call checksum,$(SHA512SUM),SHA512)
 UNPACK = $(RM) -R $@ \
        $(foreach f,$(filter %.tar.gz %.tgz,$^), && tar xvzf $(f)) \
        $(foreach f,$(filter %.tar.bz2,$^), && tar xvjf $(f)) \
        $(foreach f,$(filter %.tar.xz,$^), && tar xvJf $(f)) \
        $(foreach f,$(filter %.zip,$^), && unzip $(f))
-UNPACK_DIR = $(basename $(basename $(notdir $<)))
-APPLY = (cd $(UNPACK_DIR) && patch -p1) <
+UNPACK_DIR = $(patsubst %.tar,%,$(basename $(notdir $<)))
+APPLY = (cd $(UNPACK_DIR) && patch -fp1) <
+pkg_static = (cd $(UNPACK_DIR) && ../../../contrib/src/pkg-static.sh $(1))
 MOVE = mv $(UNPACK_DIR) $@ && touch $@
 
-RECONF = cd $< && autoreconf -fiv $(ACLOCAL_AMFLAGS)
+AUTOMAKE_DATA_DIRS=$(foreach n,$(foreach n,$(subst :, ,$(shell echo $$PATH)),$(abspath $(n)/../share)),$(wildcard $(n)/automake*))
+UPDATE_AUTOCONFIG = for dir in $(AUTOMAKE_DATA_DIRS); do \
+               if test -f "$${dir}/config.sub" -a -f "$${dir}/config.guess"; then \
+                       cp "$${dir}/config.sub" "$${dir}/config.guess" $(UNPACK_DIR); \
+                       break; \
+               fi; \
+       done
+
+RECONF = mkdir -p -- $(PREFIX)/share/aclocal && \
+       cd $< && autoreconf -fiv $(ACLOCAL_AMFLAGS)
 CMAKE = cmake . -DCMAKE_TOOLCHAIN_FILE=$(abspath toolchain.cmake) \
                -DCMAKE_INSTALL_PREFIX=$(PREFIX)
 
 #
 # Per-package build rules
 #
-include ../src/*/rules.mak
+PKGS_FOUND :=
+include $(SRC)/*/rules.mak
 
+ifeq ($(PKGS_DISABLE), all)
+PKGS :=
+endif
 #
 # Targets
 #
 ifneq ($(filter $(PKGS_DISABLE),$(PKGS_ENABLE)),)
 $(error Same package(s) disabled and enabled at the same time)
 endif
-PKGS := $(filter-out $(PKGS_DISABLE),$(PKGS)) $(PKGS_ENABLE)
+# Apply automatic selection (= remove distro packages):
+PKGS_AUTOMATIC := $(filter-out $(PKGS_FOUND),$(PKGS))
+# Apply manual selection (from bootstrap):
+PKGS_MANUAL := $(sort $(PKGS_ENABLE) $(filter-out $(PKGS_DISABLE),$(PKGS_AUTOMATIC)))
+# Resolve dependencies:
+PKGS_DEPS := $(filter-out $(PKGS_FOUND) $(PKGS_MANUAL),$(sort $(foreach p,$(PKGS_MANUAL),$(DEPS_$(p)))))
+PKGS := $(sort $(PKGS_MANUAL) $(PKGS_DEPS))
 
 fetch: $(PKGS:%=.sum-%)
-fetch-all: $(ALL_PKGS:%=.sum-%)
+fetch-all: $(PKGS_ALL:%=.sum-%)
 install: $(PKGS:%=.%)
 
 mostlyclean:
-       -$(RM) $(ALL_PKGS:%=.%) $(ALL_PKGS:%=.sum-%)
+       -$(RM) $(foreach p,$(PKGS_ALL),.$(p) .sum-$(p) .dep-$(p))
        -$(RM) toolchain.cmake
        -$(RM) -R "$(PREFIX)"
-       -find -maxdepth 1 -type d '!' -name . -exec $(RM) -R '{}' ';'
+       -$(RM) -R */
 
 clean: mostlyclean
        -$(RM) $(TARBALLS)/*.*
@@ -218,9 +362,44 @@ distclean: clean
        $(RM) config.mak
        unlink Makefile
 
+PREBUILT_URL=ftp://ftp.videolan.org/pub/videolan/contrib/$(HOST)/vlc-contrib-$(HOST)-latest.tar.bz2
+
+vlc-contrib-$(HOST)-latest.tar.bz2:
+       $(call download,$(PREBUILT_URL))
+
+prebuilt: vlc-contrib-$(HOST)-latest.tar.bz2
+       -$(UNPACK)
+       mv $(HOST) $(TOPDST)
+       cd $(TOPDST)/$(HOST) && $(SRC)/change_prefix.sh
+
 package: install
-       (cd $(PREFIX)/.. && \
-       tar cvJ $(notdir $(PREFIX))/) > ../vlc-contrib-$(HOST)-$(DATE).tar.xz
+       rm -Rf tmp/
+       mkdir -p tmp/
+       cp -R $(PREFIX) tmp/
+       # remove useless files
+       cd tmp/$(notdir $(PREFIX)); \
+               cd share; rm -Rf man doc gtk-doc info lua projectM gettext; cd ..; \
+               rm -Rf man sbin etc lib/lua lib/sidplay
+       cd tmp/$(notdir $(PREFIX)) && $(abspath $(SRC))/change_prefix.sh $(PREFIX) @@CONTRIB_PREFIX@@
+       (cd tmp && tar c $(notdir $(PREFIX))/) | bzip2 -c > ../vlc-contrib-$(HOST)-$(DATE).tar.bz2
+
+list:
+       @echo All packages:
+       @echo '  $(PKGS_ALL)' | fmt
+       @echo Distribution-provided packages:
+       @echo '  $(PKGS_FOUND)' | fmt
+       @echo Automatically selected packages:
+       @echo '  $(PKGS_AUTOMATIC)' | fmt
+       @echo Manually deselected packages:
+       @echo '  $(PKGS_DISABLE)' | fmt
+       @echo Manually selected packages:
+       @echo '  $(PKGS_ENABLE)' | fmt
+       @echo Depended-on packages:
+       @echo '  $(PKGS_DEPS)' | fmt
+       @echo To-be-built packages:
+       @echo '  $(PKGS)' | fmt
+
+.PHONY: all fetch fetch-all install mostlyclean clean distclean package list prebuilt
 
 # CMake toolchain
 toolchain.cmake:
@@ -229,11 +408,26 @@ ifdef HAVE_WIN32
        echo "set(CMAKE_SYSTEM_NAME Windows)" >> $@
        echo "set(CMAKE_RC_COMPILER $(HOST)-windres)" >> $@
 endif
-ifdef HAVE_MACOSX
+ifdef HAVE_DARWIN_OS
        echo "set(CMAKE_SYSTEM_NAME Darwin)" >> $@
        echo "set(CMAKE_C_FLAGS $(CFLAGS))" >> $@
-       echo "set(CMAKE_CXX_FLAGS $(CFLAGS)" >> $@
+       echo "set(CMAKE_CXX_FLAGS $(CFLAGS))" >> $@
        echo "set(CMAKE_LD_FLAGS $(LDFLAGS))" >> $@
+       echo "set(CMAKE_AR ar CACHE FILEPATH "Archiver")" >> $@
+ifdef HAVE_IOS
+       echo "set(CMAKE_OSX_SYSROOT $(IOS_SDK))" >> $@
+else
+       echo "set(CMAKE_OSX_SYSROOT $(MACOSX_SDK))" >> $@
+endif
+endif
+ifdef HAVE_CROSS_COMPILE
+       echo "set(_CMAKE_TOOLCHAIN_PREFIX $(HOST)-)" >> $@
+ifdef HAVE_ANDROID
+# cmake will overwrite our --sysroot with a native (host) one on Darwin
+# Set it to "" right away to short-circuit this behaviour
+       echo "set(CMAKE_CXX_SYSROOT_FLAG \"\")" >> $@
+       echo "set(CMAKE_C_SYSROOT_FLAG \"\")" >> $@
+endif
 endif
        echo "set(CMAKE_C_COMPILER $(CC))" >> $@
        echo "set(CMAKE_CXX_COMPILER $(CXX))" >> $@
@@ -242,8 +436,6 @@ endif
        echo "set(CMAKE_FIND_ROOT_PATH_MODE_LIBRARY ONLY)" >> $@
        echo "set(CMAKE_FIND_ROOT_PATH_MODE_INCLUDE ONLY)" >> $@
 
-#.SECONDEXPANSION:
-
 # Default pattern rules
 .sum-%: $(SRC)/%/SHA512SUMS
        $(CHECK_SHA512)
@@ -252,4 +444,17 @@ endif
 .sum-%:
        $(error Download and check target not defined for $*)
 
+# Dummy dependency on found packages
+$(patsubst %,.dep-%,$(PKGS_FOUND)): .dep-%:
+       touch $@
+
+# Real dependency on missing packages
+$(patsubst %,.dep-%,$(filter-out $(PKGS_FOUND),$(PKGS_ALL))): .dep-%: .%
+       touch -r $< $@
+
+.SECONDEXPANSION:
+
+# Dependency propagation (convert 'DEPS_foo = bar' to '.foo: .bar')
+$(foreach p,$(PKGS_ALL),.$(p)): .%: $$(foreach d,$$(DEPS_$$*),.dep-$$(d))
+
 .DELETE_ON_ERROR: