X-Git-Url: https://git.sesse.net/?a=blobdiff_plain;f=contrib%2Fsrc%2Fmain.mak;h=b42ea469fdd3ea1724aff6ce1e3f0014e09d9232;hb=c1f2ee018d680c70d74b2b4e73fbe0e4f4fc56e4;hp=c1c65e282dbb761285ea91970a74f7119e5d28ae;hpb=44b51330e420b7af111833adf7f2d77eb45278e6;p=vlc diff --git a/contrib/src/main.mak b/contrib/src/main.mak index c1c65e282d..b42ea469fd 100644 --- a/contrib/src/main.mak +++ b/contrib/src/main.mak @@ -5,9 +5,18 @@ all: install -PKGS_ALL := $(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 @@ -122,68 +210,113 @@ 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 $@ +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) \ @@ -193,8 +326,11 @@ CMAKE = cmake . -DCMAKE_TOOLCHAIN_FILE=$(abspath toolchain.cmake) \ # Per-package build rules # PKGS_FOUND := -include ../src/*/rules.mak +include $(SRC)/*/rules.mak +ifeq ($(PKGS_DISABLE), all) +PKGS := +endif # # Targets # @@ -217,7 +353,7 @@ mostlyclean: -$(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)/*.* @@ -226,9 +362,26 @@ 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: @@ -246,7 +399,7 @@ list: @echo To-be-built packages: @echo ' $(PKGS)' | fmt -.PHONY: all fetch fetch-all install mostlyclean clean distclean package list +.PHONY: all fetch fetch-all install mostlyclean clean distclean package list prebuilt # CMake toolchain toolchain.cmake: @@ -255,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))" >> $@