mirror of
https://git.wownero.com/wownero/wownero.git
synced 2025-01-03 09:48:53 +00:00
Merge pull request #3430
42397359
Fixup 32bit arm build (TheCharlatan)a06d2581
Fix Windows build (TheCharlatan)ecaf5b3f
Add libsodium to the packages, the arm build was complaining about it. (TheCharlatan)cbbf4d24
Adapt translations to upstream changes (TheCharlatan)db571546
Updated pcsc url (TheCharlatan)f0ba19fd
Add lrelease to the depends (TheCharlatan)cfb30462
Add Miniupnp submodule (TheCharlatan)5f7da005
Unbound is now a submodule. Adapt depends for this. (TheCharlatan)d6b9bdd3
Update readmes to reflect the usage of depends (TheCharlatan)56b6e41e
Add support for apple and arm building (TheCharlatan)29311fd1
Disable stack unwinding for mingw32 depends build. (TheCharlatan)8db3d573
Modify depends for monero's dependencies (TheCharlatan)0806a23a
Initial depends addition (TheCharlatan)
This commit is contained in:
commit
9c40bc62fc
@ -372,6 +372,9 @@ add_definitions("-DBLOCKCHAIN_DB=${BLOCKCHAIN_DB}")
|
|||||||
if (APPLE)
|
if (APPLE)
|
||||||
set(DEFAULT_STACK_TRACE OFF)
|
set(DEFAULT_STACK_TRACE OFF)
|
||||||
set(LIBUNWIND_LIBRARIES "")
|
set(LIBUNWIND_LIBRARIES "")
|
||||||
|
elseif (DEPENDS AND NOT LINUX)
|
||||||
|
set(DEFAULT_STACK_TRACE OFF)
|
||||||
|
set(LIBUNWIND_LIBRARIES "")
|
||||||
elseif(CMAKE_C_COMPILER_ID STREQUAL "GNU" AND NOT MINGW)
|
elseif(CMAKE_C_COMPILER_ID STREQUAL "GNU" AND NOT MINGW)
|
||||||
set(DEFAULT_STACK_TRACE ON)
|
set(DEFAULT_STACK_TRACE ON)
|
||||||
set(STACK_TRACE_LIB "easylogging++") # for diag output only
|
set(STACK_TRACE_LIB "easylogging++") # for diag output only
|
||||||
@ -410,6 +413,7 @@ if (CMAKE_SYSTEM_NAME MATCHES "(SunOS|Solaris)")
|
|||||||
endif ()
|
endif ()
|
||||||
|
|
||||||
if (APPLE AND NOT IOS)
|
if (APPLE AND NOT IOS)
|
||||||
|
set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -march=x86-64 -fvisibility=default")
|
||||||
if (NOT OpenSSL_DIR)
|
if (NOT OpenSSL_DIR)
|
||||||
EXECUTE_PROCESS(COMMAND brew --prefix openssl
|
EXECUTE_PROCESS(COMMAND brew --prefix openssl
|
||||||
OUTPUT_VARIABLE OPENSSL_ROOT_DIR
|
OUTPUT_VARIABLE OPENSSL_ROOT_DIR
|
||||||
@ -436,9 +440,16 @@ add_definition_if_function_found(strptime HAVE_STRPTIME)
|
|||||||
add_definitions(-DAUTO_INITIALIZE_EASYLOGGINGPP)
|
add_definitions(-DAUTO_INITIALIZE_EASYLOGGINGPP)
|
||||||
|
|
||||||
# Generate header for embedded translations
|
# Generate header for embedded translations
|
||||||
add_subdirectory(translations)
|
# Generate header for embedded translations, use target toolchain if depends, otherwise use the
|
||||||
|
# lrelease and lupdate binaries from the host
|
||||||
|
include(ExternalProject)
|
||||||
|
ExternalProject_Add(generate_translations_header
|
||||||
|
SOURCE_DIR "${CMAKE_CURRENT_SOURCE_DIR}/translations"
|
||||||
|
BINARY_DIR "${CMAKE_CURRENT_BINARY_DIR}/translations"
|
||||||
|
STAMP_DIR ${LRELEASE_PATH}
|
||||||
|
CMAKE_ARGS -DLRELEASE_PATH=${LRELEASE_PATH}
|
||||||
|
INSTALL_COMMAND cmake -E echo "")
|
||||||
include_directories("${CMAKE_CURRENT_BINARY_DIR}/translations")
|
include_directories("${CMAKE_CURRENT_BINARY_DIR}/translations")
|
||||||
|
|
||||||
add_subdirectory(external)
|
add_subdirectory(external)
|
||||||
|
|
||||||
# Final setup for libunbound
|
# Final setup for libunbound
|
||||||
@ -483,7 +494,11 @@ if(MSVC)
|
|||||||
include_directories(SYSTEM src/platform/msc)
|
include_directories(SYSTEM src/platform/msc)
|
||||||
else()
|
else()
|
||||||
include(TestCXXAcceptsFlag)
|
include(TestCXXAcceptsFlag)
|
||||||
|
if (NOT ARM6)
|
||||||
|
if(NOT DEPENDS OR DEPENDS AND NOT ARM)
|
||||||
set(ARCH native CACHE STRING "CPU to build for: -march value or 'default' to not pass -march at all")
|
set(ARCH native CACHE STRING "CPU to build for: -march value or 'default' to not pass -march at all")
|
||||||
|
endif()
|
||||||
|
endif()
|
||||||
message(STATUS "Building on ${CMAKE_SYSTEM_PROCESSOR} for ${ARCH}")
|
message(STATUS "Building on ${CMAKE_SYSTEM_PROCESSOR} for ${ARCH}")
|
||||||
if(ARCH STREQUAL "default")
|
if(ARCH STREQUAL "default")
|
||||||
set(ARCH_FLAG "")
|
set(ARCH_FLAG "")
|
||||||
@ -690,6 +705,10 @@ else()
|
|||||||
message(STATUS "Selecting VFP for ARMv6")
|
message(STATUS "Selecting VFP for ARMv6")
|
||||||
set(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} -mfpu=vfp")
|
set(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} -mfpu=vfp")
|
||||||
set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -mfpu=vfp")
|
set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -mfpu=vfp")
|
||||||
|
if(DEPENDS)
|
||||||
|
set(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} -marm")
|
||||||
|
set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -marm")
|
||||||
|
endif()
|
||||||
endif(ARM6)
|
endif(ARM6)
|
||||||
|
|
||||||
if(ARM7)
|
if(ARM7)
|
||||||
@ -744,7 +763,7 @@ else()
|
|||||||
endif()
|
endif()
|
||||||
|
|
||||||
if(APPLE)
|
if(APPLE)
|
||||||
set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -DGTEST_HAS_TR1_TUPLE=0")
|
set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -fvisibility=hidden -DGTEST_HAS_TR1_TUPLE=0")
|
||||||
endif()
|
endif()
|
||||||
|
|
||||||
set(DEBUG_FLAGS "-g3")
|
set(DEBUG_FLAGS "-g3")
|
||||||
@ -835,7 +854,11 @@ include_directories(SYSTEM ${Boost_INCLUDE_DIRS})
|
|||||||
if(MINGW)
|
if(MINGW)
|
||||||
set(CMAKE_CXX_FLAGS_DEBUG "${CMAKE_CXX_FLAGS_DEBUG} -Wa,-mbig-obj")
|
set(CMAKE_CXX_FLAGS_DEBUG "${CMAKE_CXX_FLAGS_DEBUG} -Wa,-mbig-obj")
|
||||||
set(EXTRA_LIBRARIES mswsock;ws2_32;iphlpapi;crypt32)
|
set(EXTRA_LIBRARIES mswsock;ws2_32;iphlpapi;crypt32)
|
||||||
|
if(DEPENDS)
|
||||||
|
set(ICU_LIBRARIES ${Boost_LOCALE_LIBRARY} sicuio sicuin sicuuc sicudt sicutu iconv)
|
||||||
|
else()
|
||||||
set(ICU_LIBRARIES ${Boost_LOCALE_LIBRARY} icuio icuin icuuc icudt icutu iconv)
|
set(ICU_LIBRARIES ${Boost_LOCALE_LIBRARY} icuio icuin icuuc icudt icutu iconv)
|
||||||
|
endif()
|
||||||
elseif(APPLE OR OPENBSD OR ANDROID)
|
elseif(APPLE OR OPENBSD OR ANDROID)
|
||||||
set(EXTRA_LIBRARIES "")
|
set(EXTRA_LIBRARIES "")
|
||||||
elseif(FREEBSD)
|
elseif(FREEBSD)
|
||||||
|
18
README.md
18
README.md
@ -477,7 +477,7 @@ Then you can run make as usual.
|
|||||||
# Get binaries
|
# Get binaries
|
||||||
docker cp monero-android:/opt/android/monero/build/release/bin .
|
docker cp monero-android:/opt/android/monero/build/release/bin .
|
||||||
|
|
||||||
### Building portable statically linked binaries
|
### Building portable statically linked binaries (Cross Compiling)
|
||||||
|
|
||||||
By default, in either dynamically or statically linked builds, binaries target the specific host processor on which the build happens and are not portable to other processors. Portable binaries can be built using the following targets:
|
By default, in either dynamically or statically linked builds, binaries target the specific host processor on which the build happens and are not portable to other processors. Portable binaries can be built using the following targets:
|
||||||
|
|
||||||
@ -532,6 +532,22 @@ Installing a snap is very quick. Snaps are secure. They are isolated with all of
|
|||||||
|
|
||||||
Packaging for your favorite distribution would be a welcome contribution!
|
Packaging for your favorite distribution would be a welcome contribution!
|
||||||
|
|
||||||
|
You can also cross-compile binaries on linux for windows and macos with the depends system. Go to contrib/depends and type:
|
||||||
|
|
||||||
|
* ```make HOST=x86_64-linux-gnu``` for 64-bit linux binaries.
|
||||||
|
* ```make HOST=x86_64-w64-mingw32``` for 64-bit windows binaries. Requires: python3 nsis g++-mingw-w64-x86-64 wine1.6 bc
|
||||||
|
* ```make HOST=x86_64-apple-darwin11``` for darwin binaries. Requires: cmake imagemagick libcap-dev librsvg2-bin libz-dev libbz2-dev libtiff-tools python-dev
|
||||||
|
* ```make HOST=i686-linux-gnu``` for 32-bit linux binaries. Requires: g++-multilib bc
|
||||||
|
* ```make HOST=i686-w64-mingw32``` for 32-bit windows binaries. Requires: python3 nsis g++-mingw-w64-i686
|
||||||
|
* ```make HOST=arm-linux-gnueabihf``` for armv6 binaries. Requires: g++-arm-linux-gnueabihf
|
||||||
|
|
||||||
|
The required packages are the names for each toolchain on apt. Depending on your distro, they may have different names.
|
||||||
|
Then go back to the source dir and type for example for windows 64bit:
|
||||||
|
|
||||||
|
* ```cmake -DCMAKE_TOOLCHAIN_FILE=`pwd`/contrib/depends/x86_64-w64-mingw32```
|
||||||
|
|
||||||
|
Using depends might also be easier to compile monero on windows than using msys. Activate windows subsystem for linux (for example ubuntu) install the apt build-essentials and follow the depends steps as depicted above.
|
||||||
|
|
||||||
## Running monerod
|
## Running monerod
|
||||||
|
|
||||||
The build places the binary in `bin/` sub-directory within the build directory
|
The build places the binary in `bin/` sub-directory within the build directory
|
||||||
|
@ -46,8 +46,9 @@ FIND_PACKAGE_HANDLE_STANDARD_ARGS(PCSC DEFAULT_MSG PCSC_LIBRARY PCSC_INCLUDE_DIR
|
|||||||
|
|
||||||
IF(PCSC_FOUND)
|
IF(PCSC_FOUND)
|
||||||
SET( PCSC_LIBRARIES ${PCSC_LIBRARY} )
|
SET( PCSC_LIBRARIES ${PCSC_LIBRARY} )
|
||||||
|
SET(PCSC_STATIC_LIBRARIES ${PCSC_STATIC_LIBRARY})
|
||||||
ELSE(PCSC_FOUND)
|
ELSE(PCSC_FOUND)
|
||||||
SET( PCSC_LIBRARIES )
|
SET( PCSC_LIBRARIES )
|
||||||
ENDIF(PCSC_FOUND)
|
ENDIF(PCSC_FOUND)
|
||||||
|
|
||||||
MARK_AS_ADVANCED( PCSC_LIBRARY PCSC_INCLUDE_DIR )
|
MARK_AS_ADVANCED( PCSC_LIBRARY PCSC_INCLUDE_DIR PCSC_STATIC_LIBRARY)
|
||||||
|
10
contrib/depends/.gitignore
vendored
Normal file
10
contrib/depends/.gitignore
vendored
Normal file
@ -0,0 +1,10 @@
|
|||||||
|
SDKs/
|
||||||
|
work/
|
||||||
|
built/
|
||||||
|
sources/
|
||||||
|
config.site
|
||||||
|
x86_64*
|
||||||
|
i686*
|
||||||
|
mips*
|
||||||
|
arm*
|
||||||
|
aarch64*
|
227
contrib/depends/Makefile
Normal file
227
contrib/depends/Makefile
Normal file
@ -0,0 +1,227 @@
|
|||||||
|
.NOTPARALLEL :
|
||||||
|
|
||||||
|
SOURCES_PATH ?= $(BASEDIR)/sources
|
||||||
|
BASE_CACHE ?= $(BASEDIR)/built
|
||||||
|
SDK_PATH ?= $(BASEDIR)/SDKs
|
||||||
|
NO_QT ?=
|
||||||
|
NO_WALLET ?=
|
||||||
|
NO_UPNP ?=
|
||||||
|
FALLBACK_DOWNLOAD_PATH ?= https://bitcoincore.org/depends-sources
|
||||||
|
|
||||||
|
BUILD = $(shell ./config.guess)
|
||||||
|
HOST ?= $(BUILD)
|
||||||
|
PATCHES_PATH = $(BASEDIR)/patches
|
||||||
|
BASEDIR = $(CURDIR)
|
||||||
|
HASH_LENGTH:=11
|
||||||
|
DOWNLOAD_CONNECT_TIMEOUT:=10
|
||||||
|
DOWNLOAD_RETRIES:=3
|
||||||
|
HOST_ID_SALT ?= salt
|
||||||
|
BUILD_ID_SALT ?= salt
|
||||||
|
|
||||||
|
host:=$(BUILD)
|
||||||
|
ifneq ($(HOST),)
|
||||||
|
host:=$(HOST)
|
||||||
|
host_toolchain:=$(HOST)-
|
||||||
|
endif
|
||||||
|
|
||||||
|
ifneq ($(DEBUG),)
|
||||||
|
release_type=debug
|
||||||
|
else
|
||||||
|
release_type=release
|
||||||
|
endif
|
||||||
|
|
||||||
|
base_build_dir=$(BASEDIR)/work/build
|
||||||
|
base_staging_dir=$(BASEDIR)/work/staging
|
||||||
|
base_download_dir=$(BASEDIR)/work/download
|
||||||
|
canonical_host:=$(shell ./config.sub $(HOST))
|
||||||
|
build:=$(shell ./config.sub $(BUILD))
|
||||||
|
|
||||||
|
build_arch =$(firstword $(subst -, ,$(build)))
|
||||||
|
build_vendor=$(word 2,$(subst -, ,$(build)))
|
||||||
|
full_build_os:=$(subst $(build_arch)-$(build_vendor)-,,$(build))
|
||||||
|
build_os:=$(findstring linux,$(full_build_os))
|
||||||
|
build_os+=$(findstring darwin,$(full_build_os))
|
||||||
|
build_os:=$(strip $(build_os))
|
||||||
|
ifeq ($(build_os),)
|
||||||
|
build_os=$(full_build_os)
|
||||||
|
endif
|
||||||
|
|
||||||
|
host_arch=$(firstword $(subst -, ,$(canonical_host)))
|
||||||
|
host_vendor=$(word 2,$(subst -, ,$(canonical_host)))
|
||||||
|
full_host_os:=$(subst $(host_arch)-$(host_vendor)-,,$(canonical_host))
|
||||||
|
host_os:=$(findstring linux,$(full_host_os))
|
||||||
|
host_os+=$(findstring darwin,$(full_host_os))
|
||||||
|
host_os+=$(findstring mingw32,$(full_host_os))
|
||||||
|
host_os:=$(strip $(host_os))
|
||||||
|
ifeq ($(host_os),)
|
||||||
|
host_os=$(full_host_os)
|
||||||
|
endif
|
||||||
|
|
||||||
|
$(host_arch)_$(host_os)_prefix=$(BASEDIR)/$(host)
|
||||||
|
$(host_arch)_$(host_os)_host=$(host)
|
||||||
|
host_prefix=$($(host_arch)_$(host_os)_prefix)
|
||||||
|
build_prefix=$(host_prefix)/native
|
||||||
|
ifeq ($(host_os),mingw32)
|
||||||
|
host_cmake=Windows
|
||||||
|
endif
|
||||||
|
ifeq ($(host_os),linux)
|
||||||
|
host_cmake=Linux
|
||||||
|
endif
|
||||||
|
ifeq ($(host_os),darwin)
|
||||||
|
host_cmake=Darwin
|
||||||
|
endif
|
||||||
|
|
||||||
|
AT_$(V):=
|
||||||
|
AT_:=@
|
||||||
|
AT:=$(AT_$(V))
|
||||||
|
|
||||||
|
all: install
|
||||||
|
|
||||||
|
include hosts/$(host_os).mk
|
||||||
|
include hosts/default.mk
|
||||||
|
include builders/$(build_os).mk
|
||||||
|
include builders/default.mk
|
||||||
|
include packages/packages.mk
|
||||||
|
|
||||||
|
build_id_string:=$(BUILD_ID_SALT)
|
||||||
|
build_id_string+=$(shell $(build_CC) --version 2>/dev/null)
|
||||||
|
build_id_string+=$(shell $(build_AR) --version 2>/dev/null)
|
||||||
|
build_id_string+=$(shell $(build_CXX) --version 2>/dev/null)
|
||||||
|
build_id_string+=$(shell $(build_RANLIB) --version 2>/dev/null)
|
||||||
|
build_id_string+=$(shell $(build_STRIP) --version 2>/dev/null)
|
||||||
|
|
||||||
|
$(host_arch)_$(host_os)_id_string:=$(HOST_ID_SALT)
|
||||||
|
$(host_arch)_$(host_os)_id_string+=$(shell $(host_CC) --version 2>/dev/null)
|
||||||
|
$(host_arch)_$(host_os)_id_string+=$(shell $(host_AR) --version 2>/dev/null)
|
||||||
|
$(host_arch)_$(host_os)_id_string+=$(shell $(host_CXX) --version 2>/dev/null)
|
||||||
|
$(host_arch)_$(host_os)_id_string+=$(shell $(host_RANLIB) --version 2>/dev/null)
|
||||||
|
$(host_arch)_$(host_os)_id_string+=$(shell $(host_STRIP) --version 2>/dev/null)
|
||||||
|
|
||||||
|
qt_packages_$(NO_QT) = $(qt_packages) $(qt_$(host_os)_packages) $(qt_$(host_arch)_$(host_os)_packages)
|
||||||
|
wallet_packages_$(NO_WALLET) = $(wallet_packages)
|
||||||
|
upnp_packages_$(NO_UPNP) = $(upnp_packages)
|
||||||
|
|
||||||
|
packages += $($(host_arch)_$(host_os)_packages) $($(host_os)_packages) $(qt_packages_) $(wallet_packages_) $(upnp_packages_)
|
||||||
|
native_packages += $($(host_arch)_$(host_os)_native_packages) $($(host_os)_native_packages)
|
||||||
|
|
||||||
|
ifneq ($(qt_packages_),)
|
||||||
|
native_packages += $(qt_native_packages)
|
||||||
|
endif
|
||||||
|
|
||||||
|
all_packages = $(packages) $(native_packages)
|
||||||
|
|
||||||
|
meta_depends = Makefile funcs.mk builders/default.mk hosts/default.mk hosts/$(host_os).mk builders/$(build_os).mk
|
||||||
|
|
||||||
|
$(host_arch)_$(host_os)_native_toolchain?=$($(host_os)_native_toolchain)
|
||||||
|
|
||||||
|
include funcs.mk
|
||||||
|
|
||||||
|
CONF_PKGS := cmake-conf mxe-conf
|
||||||
|
|
||||||
|
build-only-$(1)_$(3): CMAKE_RUNRESULT_FILE = $(PREFIX)/share/cmake/modules/TryRunResults.cmake
|
||||||
|
build-only-$(1)_$(3): CMAKE_TOOLCHAIN_FILE = $(PREFIX)/$(3)/share/cmake/mxe-conf.cmake
|
||||||
|
build-only-$(1)_$(3): CMAKE_TOOLCHAIN_DIR = $(PREFIX)/$(3)/share/cmake/mxe-conf.d
|
||||||
|
build-only-$(1)_$(3): CMAKE_STATIC_BOOL = $(if $(findstring shared,$(3)),OFF,ON)
|
||||||
|
build-only-$(1)_$(3): CMAKE_SHARED_BOOL = $(if $(findstring shared,$(3)),ON,OFF)
|
||||||
|
|
||||||
|
|
||||||
|
toolchain_path=$($($(host_arch)_$(host_os)_native_toolchain)_prefixbin)
|
||||||
|
final_build_id_long+=$(shell $(build_SHA256SUM) config.site.in)
|
||||||
|
final_build_id_long+=$(shell $(build_SHA256SUM) toolchain.cmake.in)
|
||||||
|
final_build_id+=$(shell echo -n "$(final_build_id_long)" | $(build_SHA256SUM) | cut -c-$(HASH_LENGTH))
|
||||||
|
$(host_prefix)/.stamp_$(final_build_id): $(native_packages) $(packages)
|
||||||
|
$(AT)rm -rf $(@D)
|
||||||
|
$(AT)mkdir -p $(@D)
|
||||||
|
$(AT)echo copying packages: $^
|
||||||
|
$(AT)echo to: $(@D)
|
||||||
|
$(AT)cd $(@D); $(foreach package,$^, tar xf $($(package)_cached); )
|
||||||
|
$(AT)touch $@
|
||||||
|
|
||||||
|
$(host_prefix)/share/config.site : config.site.in $(host_prefix)/.stamp_$(final_build_id)
|
||||||
|
$(AT)@mkdir -p $(@D)
|
||||||
|
$(AT)sed -e 's|@HOST@|$(host)|' \
|
||||||
|
-e 's|@CC@|$(toolchain_path)$(host_CC)|' \
|
||||||
|
-e 's|@CXX@|$(toolchain_path)$(host_CXX)|' \
|
||||||
|
-e 's|@AR@|$(toolchain_path)$(host_AR)|' \
|
||||||
|
-e 's|@RANLIB@|$(toolchain_path)$(host_RANLIB)|' \
|
||||||
|
-e 's|@NM@|$(toolchain_path)$(host_NM)|' \
|
||||||
|
-e 's|@STRIP@|$(toolchain_path)$(host_STRIP)|' \
|
||||||
|
-e 's|@build_os@|$(build_os)|' \
|
||||||
|
-e 's|@host_os@|$(host_os)|' \
|
||||||
|
-e 's|@CFLAGS@|$(strip $(host_CFLAGS) $(host_$(release_type)_CFLAGS))|' \
|
||||||
|
-e 's|@CXXFLAGS@|$(strip $(host_CXXFLAGS) $(host_$(release_type)_CXXFLAGS))|' \
|
||||||
|
-e 's|@CPPFLAGS@|$(strip $(host_CPPFLAGS) $(host_$(release_type)_CPPFLAGS))|' \
|
||||||
|
-e 's|@LDFLAGS@|$(strip $(host_LDFLAGS) $(host_$(release_type)_LDFLAGS))|' \
|
||||||
|
-e 's|@allow_host_packages@|$(ALLOW_HOST_PACKAGES)|' \
|
||||||
|
-e 's|@no_qt@|$(NO_QT)|' \
|
||||||
|
-e 's|@no_wallet@|$(NO_WALLET)|' \
|
||||||
|
-e 's|@no_upnp@|$(NO_UPNP)|' \
|
||||||
|
-e 's|@debug@|$(DEBUG)|' \
|
||||||
|
$< > $@
|
||||||
|
$(AT)touch $@
|
||||||
|
|
||||||
|
$(host_prefix)/share/toolchain.cmake : toolchain.cmake.in $(host_prefix)/.stamp_$(final_build_id)
|
||||||
|
$(AT)@mkdir -p $(@D)
|
||||||
|
$(AT)sed -e 's|@HOST@|$(host)|' \
|
||||||
|
-e 's|@CC@|$(toolchain_path)$(host_CC)|' \
|
||||||
|
-e 's|@CXX@|$(toolchain_path)$(host_CXX)|' \
|
||||||
|
-e 's|@AR@|$(toolchain_path)$(host_AR)|' \
|
||||||
|
-e 's|@RANLIB@|$(toolchain_path)$(host_RANLIB)|' \
|
||||||
|
-e 's|@NM@|$(toolchain_path)$(host_NM)|' \
|
||||||
|
-e 's|@STRIP@|$(toolchain_path)$(host_STRIP)|' \
|
||||||
|
-e 's|@build_os@|$(build_os)|' \
|
||||||
|
-e 's|@host_os@|$(host_os)|' \
|
||||||
|
-e 's|@CFLAGS@|$(strip $(host_CFLAGS) $(host_$(release_type)_CFLAGS))|' \
|
||||||
|
-e 's|@CXXFLAGS@|$(strip $(host_CXXFLAGS) $(host_$(release_type)_CXXFLAGS))|' \
|
||||||
|
-e 's|@CPPFLAGS@|$(strip $(host_CPPFLAGS) $(host_$(release_type)_CPPFLAGS))|' \
|
||||||
|
-e 's|@LDFLAGS@|$(strip $(host_LDFLAGS) $(host_$(release_type)_LDFLAGS))|' \
|
||||||
|
-e 's|@allow_host_packages@|$(ALLOW_HOST_PACKAGES)|' \
|
||||||
|
-e 's|@no_qt@|$(NO_QT)|' \
|
||||||
|
-e 's|@no_wallet@|$(NO_WALLET)|' \
|
||||||
|
-e 's|@no_upnp@|$(NO_UPNP)|' \
|
||||||
|
-e 's|@debug@|$(DEBUG)|' \
|
||||||
|
-e 's|@depends@|$(host_cmake)|' \
|
||||||
|
-e 's|@prefix@|$($(host_arch)_$(host_os)_prefix)|'\
|
||||||
|
-e 's|@sdk@|$(SDK_PATH)|'\
|
||||||
|
-e 's|@arch@|$(host_arch)|'\
|
||||||
|
$< > $@
|
||||||
|
$(AT)touch $@
|
||||||
|
|
||||||
|
define check_or_remove_cached
|
||||||
|
mkdir -p $(BASE_CACHE)/$(host)/$(package) && cd $(BASE_CACHE)/$(host)/$(package); \
|
||||||
|
$(build_SHA256SUM) -c $($(package)_cached_checksum) >/dev/null 2>/dev/null || \
|
||||||
|
( rm -f $($(package)_cached_checksum); \
|
||||||
|
if test -f "$($(package)_cached)"; then echo "Checksum mismatch for $(package). Forcing rebuild.."; rm -f $($(package)_cached_checksum) $($(package)_cached); fi )
|
||||||
|
endef
|
||||||
|
|
||||||
|
define check_or_remove_sources
|
||||||
|
mkdir -p $($(package)_source_dir); cd $($(package)_source_dir); \
|
||||||
|
test -f $($(package)_fetched) && ( $(build_SHA256SUM) -c $($(package)_fetched) >/dev/null 2>/dev/null || \
|
||||||
|
( echo "Checksum missing or mismatched for $(package) source. Forcing re-download."; \
|
||||||
|
rm -f $($(package)_all_sources) $($(1)_fetched))) || true
|
||||||
|
endef
|
||||||
|
|
||||||
|
check-packages:
|
||||||
|
@$(foreach package,$(all_packages),$(call check_or_remove_cached,$(package));)
|
||||||
|
check-sources:
|
||||||
|
@$(foreach package,$(all_packages),$(call check_or_remove_sources,$(package));)
|
||||||
|
|
||||||
|
$(host_prefix)/share/config.site: check-packages
|
||||||
|
$(host_prefix)/share/toolchain.cmake: check-packages
|
||||||
|
|
||||||
|
check-packages: check-sources
|
||||||
|
|
||||||
|
install: check-packages $(host_prefix)/share/config.site
|
||||||
|
install: check-packages $(host_prefix)/share/toolchain.cmake
|
||||||
|
|
||||||
|
download-one: check-sources $(all_sources)
|
||||||
|
|
||||||
|
download-osx:
|
||||||
|
@$(MAKE) -s HOST=x86_64-apple-darwin11 download-one
|
||||||
|
download-linux:
|
||||||
|
@$(MAKE) -s HOST=x86_64-unknown-linux-gnu download-one
|
||||||
|
download-win:
|
||||||
|
@$(MAKE) -s HOST=x86_64-w64-mingw32 download-one
|
||||||
|
download: download-osx download-linux download-win
|
||||||
|
|
||||||
|
.PHONY: install cached download-one download-osx download-linux download-win download check-packages check-sources
|
66
contrib/depends/README.md
Normal file
66
contrib/depends/README.md
Normal file
@ -0,0 +1,66 @@
|
|||||||
|
### Usage
|
||||||
|
|
||||||
|
To build dependencies for the current arch+OS:
|
||||||
|
|
||||||
|
make
|
||||||
|
|
||||||
|
To build for another arch/OS:
|
||||||
|
|
||||||
|
make HOST=host-platform-triplet
|
||||||
|
|
||||||
|
For example:
|
||||||
|
|
||||||
|
make HOST=x86_64-w64-mingw32 -j4
|
||||||
|
|
||||||
|
A prefix will be generated that's suitable for plugging into Bitcoin's
|
||||||
|
configure. In the above example, a dir named x86_64-w64-mingw32 will be
|
||||||
|
created. To use it for Bitcoin:
|
||||||
|
|
||||||
|
./configure --prefix=`pwd`/depends/x86_64-w64-mingw32
|
||||||
|
|
||||||
|
Common `host-platform-triplets` for cross compilation are:
|
||||||
|
|
||||||
|
- `i686-w64-mingw32` for Win32
|
||||||
|
- `x86_64-w64-mingw32` for Win64
|
||||||
|
- `x86_64-apple-darwin11` for MacOSX
|
||||||
|
- `arm-linux-gnueabihf` for Linux ARM 32 bit
|
||||||
|
- `aarch64-linux-gnu` for Linux ARM 64 bit
|
||||||
|
|
||||||
|
No other options are needed, the paths are automatically configured.
|
||||||
|
|
||||||
|
Dependency Options:
|
||||||
|
The following can be set when running make: make FOO=bar
|
||||||
|
|
||||||
|
SOURCES_PATH: downloaded sources will be placed here
|
||||||
|
BASE_CACHE: built packages will be placed here
|
||||||
|
SDK_PATH: Path where sdk's can be found (used by OSX)
|
||||||
|
FALLBACK_DOWNLOAD_PATH: If a source file can't be fetched, try here before giving up
|
||||||
|
NO_QT: Don't download/build/cache qt and its dependencies
|
||||||
|
NO_WALLET: Don't download/build/cache libs needed to enable the wallet
|
||||||
|
NO_UPNP: Don't download/build/cache packages needed for enabling upnp
|
||||||
|
DEBUG: disable some optimizations and enable more runtime checking
|
||||||
|
HOST_ID_SALT: Optional salt to use when generating host package ids
|
||||||
|
BUILD_ID_SALT: Optional salt to use when generating build package ids
|
||||||
|
|
||||||
|
If some packages are not built, for example `make NO_WALLET=1`, the appropriate
|
||||||
|
options will be passed to bitcoin's configure. In this case, `--disable-wallet`.
|
||||||
|
|
||||||
|
Additional targets:
|
||||||
|
|
||||||
|
download: run 'make download' to fetch all sources without building them
|
||||||
|
download-osx: run 'make download-osx' to fetch all sources needed for osx builds
|
||||||
|
download-win: run 'make download-win' to fetch all sources needed for win builds
|
||||||
|
download-linux: run 'make download-linux' to fetch all sources needed for linux builds
|
||||||
|
|
||||||
|
#Darwin (macos) builds:
|
||||||
|
|
||||||
|
To build with the x86_64-apple-darwin11 you require the mac os developer tools in MacOSX10.11.sdk.
|
||||||
|
Download it from apple, or search for it on github. Create a new directoty called SDKs in this
|
||||||
|
directory and place the entire MacOSX10.11.sdk folder in it. The depends build will then pick it up automatically
|
||||||
|
(without requiring SDK_PATH).
|
||||||
|
|
||||||
|
### Other documentation
|
||||||
|
|
||||||
|
- [description.md](description.md): General description of the depends system
|
||||||
|
- [packages.md](packages.md): Steps for adding packages
|
||||||
|
|
22
contrib/depends/builders/darwin.mk
Normal file
22
contrib/depends/builders/darwin.mk
Normal file
@ -0,0 +1,22 @@
|
|||||||
|
build_darwin_CC: = $(shell xcrun -f clang)
|
||||||
|
build_darwin_CXX: = $(shell xcrun -f clang++)
|
||||||
|
build_darwin_AR: = $(shell xcrun -f ar)
|
||||||
|
build_darwin_RANLIB: = $(shell xcrun -f ranlib)
|
||||||
|
build_darwin_STRIP: = $(shell xcrun -f strip)
|
||||||
|
build_darwin_OTOOL: = $(shell xcrun -f otool)
|
||||||
|
build_darwin_NM: = $(shell xcrun -f nm)
|
||||||
|
build_darwin_INSTALL_NAME_TOOL:=$(shell xcrun -f install_name_tool)
|
||||||
|
build_darwin_SHA256SUM = shasum -a 256
|
||||||
|
build_darwin_DOWNLOAD = curl --location --fail --connect-timeout $(DOWNLOAD_CONNECT_TIMEOUT) --retry $(DOWNLOAD_RETRIES) -o
|
||||||
|
|
||||||
|
#darwin host on darwin builder. overrides darwin host preferences.
|
||||||
|
darwin_CC=$(shell xcrun -f clang) -mmacosx-version-min=$(OSX_MIN_VERSION)
|
||||||
|
darwin_CXX:=$(shell xcrun -f clang++) -mmacosx-version-min=$(OSX_MIN_VERSION) -stdlib=libc++
|
||||||
|
darwin_AR:=$(shell xcrun -f ar)
|
||||||
|
darwin_RANLIB:=$(shell xcrun -f ranlib)
|
||||||
|
darwin_STRIP:=$(shell xcrun -f strip)
|
||||||
|
darwin_LIBTOOL:=$(shell xcrun -f libtool)
|
||||||
|
darwin_OTOOL:=$(shell xcrun -f otool)
|
||||||
|
darwin_NM:=$(shell xcrun -f nm)
|
||||||
|
darwin_INSTALL_NAME_TOOL:=$(shell xcrun -f install_name_tool)
|
||||||
|
darwin_native_toolchain=
|
20
contrib/depends/builders/default.mk
Normal file
20
contrib/depends/builders/default.mk
Normal file
@ -0,0 +1,20 @@
|
|||||||
|
default_build_CC = gcc
|
||||||
|
default_build_CXX = g++
|
||||||
|
default_build_AR = ar
|
||||||
|
default_build_RANLIB = ranlib
|
||||||
|
default_build_STRIP = strip
|
||||||
|
default_build_NM = nm
|
||||||
|
default_build_OTOOL = otool
|
||||||
|
default_build_INSTALL_NAME_TOOL = install_name_tool
|
||||||
|
|
||||||
|
define add_build_tool_func
|
||||||
|
build_$(build_os)_$1 ?= $$(default_build_$1)
|
||||||
|
build_$(build_arch)_$(build_os)_$1 ?= $$(build_$(build_os)_$1)
|
||||||
|
build_$1=$$(build_$(build_arch)_$(build_os)_$1)
|
||||||
|
endef
|
||||||
|
$(foreach var,CC CXX AR RANLIB NM STRIP SHA256SUM DOWNLOAD OTOOL INSTALL_NAME_TOOL,$(eval $(call add_build_tool_func,$(var))))
|
||||||
|
define add_build_flags_func
|
||||||
|
build_$(build_arch)_$(build_os)_$1 += $(build_$(build_os)_$1)
|
||||||
|
build_$1=$$(build_$(build_arch)_$(build_os)_$1)
|
||||||
|
endef
|
||||||
|
$(foreach flags, CFLAGS CXXFLAGS LDFLAGS, $(eval $(call add_build_flags_func,$(flags))))
|
2
contrib/depends/builders/linux.mk
Normal file
2
contrib/depends/builders/linux.mk
Normal file
@ -0,0 +1,2 @@
|
|||||||
|
build_linux_SHA256SUM = sha256sum
|
||||||
|
build_linux_DOWNLOAD = curl --location --fail --connect-timeout $(DOWNLOAD_CONNECT_TIMEOUT) --retry $(DOWNLOAD_RETRIES) -o
|
1466
contrib/depends/config.guess
vendored
Executable file
1466
contrib/depends/config.guess
vendored
Executable file
File diff suppressed because it is too large
Load Diff
100
contrib/depends/config.site.in
Normal file
100
contrib/depends/config.site.in
Normal file
@ -0,0 +1,100 @@
|
|||||||
|
depends_prefix="`dirname ${ac_site_file}`/.."
|
||||||
|
|
||||||
|
cross_compiling=maybe
|
||||||
|
host_alias=@HOST@
|
||||||
|
ac_tool_prefix=${host_alias}-
|
||||||
|
|
||||||
|
if test -z $with_boost; then
|
||||||
|
with_boost=$depends_prefix
|
||||||
|
fi
|
||||||
|
if test -z $with_qt_plugindir; then
|
||||||
|
with_qt_plugindir=$depends_prefix/plugins
|
||||||
|
fi
|
||||||
|
if test -z $with_qt_translationdir; then
|
||||||
|
with_qt_translationdir=$depends_prefix/translations
|
||||||
|
fi
|
||||||
|
if test -z $with_qt_bindir && test -z "@no_qt@"; then
|
||||||
|
with_qt_bindir=$depends_prefix/native/bin
|
||||||
|
fi
|
||||||
|
if test -z $with_protoc_bindir && test -z "@no_qt@"; then
|
||||||
|
with_protoc_bindir=$depends_prefix/native/bin
|
||||||
|
fi
|
||||||
|
|
||||||
|
|
||||||
|
if test -z $enable_wallet && test -n "@no_wallet@"; then
|
||||||
|
enable_wallet=no
|
||||||
|
fi
|
||||||
|
|
||||||
|
if test -z $with_miniupnpc && test -n "@no_upnp@"; then
|
||||||
|
with_miniupnpc=no
|
||||||
|
fi
|
||||||
|
|
||||||
|
if test -z $with_gui && test -n "@no_qt@"; then
|
||||||
|
with_gui=no
|
||||||
|
fi
|
||||||
|
|
||||||
|
if test x@host_os@ = xdarwin; then
|
||||||
|
BREW=no
|
||||||
|
PORT=no
|
||||||
|
fi
|
||||||
|
|
||||||
|
if test x@host_os@ = xmingw32; then
|
||||||
|
if test -z $with_qt_incdir; then
|
||||||
|
with_qt_incdir=$depends_prefix/include
|
||||||
|
fi
|
||||||
|
if test -z $with_qt_libdir; then
|
||||||
|
with_qt_libdir=$depends_prefix/lib
|
||||||
|
fi
|
||||||
|
fi
|
||||||
|
|
||||||
|
PATH=$depends_prefix/native/bin:$PATH
|
||||||
|
PKG_CONFIG="`which pkg-config` --static"
|
||||||
|
|
||||||
|
# These two need to remain exported because pkg-config does not see them
|
||||||
|
# otherwise. That means they must be unexported at the end of configure.ac to
|
||||||
|
# avoid ruining the cache. Sigh.
|
||||||
|
export PKG_CONFIG_PATH=$depends_prefix/share/pkgconfig:$depends_prefix/lib/pkgconfig
|
||||||
|
if test -z "@allow_host_packages@"; then
|
||||||
|
export PKGCONFIG_LIBDIR=
|
||||||
|
fi
|
||||||
|
|
||||||
|
CPPFLAGS="-I$depends_prefix/include/ $CPPFLAGS"
|
||||||
|
LDFLAGS="-L$depends_prefix/lib $LDFLAGS"
|
||||||
|
|
||||||
|
CC="@CC@"
|
||||||
|
CXX="@CXX@"
|
||||||
|
OBJC="${CC}"
|
||||||
|
CCACHE=$depends_prefix/native/bin/ccache
|
||||||
|
PYTHONPATH=$depends_prefix/native/lib/python/dist-packages:$PYTHONPATH
|
||||||
|
|
||||||
|
if test -n "@AR@"; then
|
||||||
|
AR=@AR@
|
||||||
|
ac_cv_path_ac_pt_AR=${AR}
|
||||||
|
fi
|
||||||
|
|
||||||
|
if test -n "@RANLIB@"; then
|
||||||
|
RANLIB=@RANLIB@
|
||||||
|
ac_cv_path_ac_pt_RANLIB=${RANLIB}
|
||||||
|
fi
|
||||||
|
|
||||||
|
if test -n "@NM@"; then
|
||||||
|
NM=@NM@
|
||||||
|
ac_cv_path_ac_pt_NM=${NM}
|
||||||
|
fi
|
||||||
|
|
||||||
|
if test -n "@debug@"; then
|
||||||
|
enable_reduce_exports=no
|
||||||
|
fi
|
||||||
|
|
||||||
|
if test -n "@CFLAGS@"; then
|
||||||
|
CFLAGS="@CFLAGS@ $CFLAGS"
|
||||||
|
fi
|
||||||
|
if test -n "@CXXFLAGS@"; then
|
||||||
|
CXXFLAGS="@CXXFLAGS@ $CXXFLAGS"
|
||||||
|
fi
|
||||||
|
if test -n "@CPPFLAGS@"; then
|
||||||
|
CPPFLAGS="@CPPFLAGS@ $CPPFLAGS"
|
||||||
|
fi
|
||||||
|
if test -n "@LDFLAGS@"; then
|
||||||
|
LDFLAGS="@LDFLAGS@ $LDFLAGS"
|
||||||
|
fi
|
1836
contrib/depends/config.sub
vendored
Executable file
1836
contrib/depends/config.sub
vendored
Executable file
File diff suppressed because it is too large
Load Diff
53
contrib/depends/description.md
Normal file
53
contrib/depends/description.md
Normal file
@ -0,0 +1,53 @@
|
|||||||
|
This is a system of building and caching dependencies necessary for building Bitcoin.
|
||||||
|
There are several features that make it different from most similar systems:
|
||||||
|
|
||||||
|
### It is designed to be builder and host agnostic
|
||||||
|
|
||||||
|
In theory, binaries for any target OS/architecture can be created, from a
|
||||||
|
builder running any OS/architecture. In practice, build-side tools must be
|
||||||
|
specified when the defaults don't fit, and packages must be amended to work
|
||||||
|
on new hosts. For now, a build architecture of x86_64 is assumed, either on
|
||||||
|
Linux or OSX.
|
||||||
|
|
||||||
|
### No reliance on timestamps
|
||||||
|
|
||||||
|
File presence is used to determine what needs to be built. This makes the
|
||||||
|
results distributable and easily digestable by automated builders.
|
||||||
|
|
||||||
|
### Each build only has its specified dependencies available at build-time.
|
||||||
|
|
||||||
|
For each build, the sysroot is wiped and the (recursive) dependencies are
|
||||||
|
installed. This makes each build deterministic, since there will never be any
|
||||||
|
unknown files available to cause side-effects.
|
||||||
|
|
||||||
|
### Each package is cached and only rebuilt as needed.
|
||||||
|
|
||||||
|
Before building, a unique build-id is generated for each package. This id
|
||||||
|
consists of a hash of all files used to build the package (Makefiles, packages,
|
||||||
|
etc), and as well as a hash of the same data for each recursive dependency. If
|
||||||
|
any portion of a package's build recipe changes, it will be rebuilt as well as
|
||||||
|
any other package that depends on it. If any of the main makefiles (Makefile,
|
||||||
|
funcs.mk, etc) are changed, all packages will be rebuilt. After building, the
|
||||||
|
results are cached into a tarball that can be re-used and distributed.
|
||||||
|
|
||||||
|
### Package build results are (relatively) deterministic.
|
||||||
|
|
||||||
|
Each package is configured and patched so that it will yield the same
|
||||||
|
build-results with each consequent build, within a reasonable set of
|
||||||
|
constraints. Some things like timestamp insertion are unavoidable, and are
|
||||||
|
beyond the scope of this system. Additionally, the toolchain itself must be
|
||||||
|
capable of deterministic results. When revisions are properly bumped, a cached
|
||||||
|
build should represent an exact single payload.
|
||||||
|
|
||||||
|
### Sources are fetched and verified automatically
|
||||||
|
|
||||||
|
Each package must define its source location and checksum. The build will fail
|
||||||
|
if the fetched source does not match. Sources may be pre-seeded and/or cached
|
||||||
|
as desired.
|
||||||
|
|
||||||
|
### Self-cleaning
|
||||||
|
|
||||||
|
Build and staging dirs are wiped after use, and any previous version of a
|
||||||
|
cached result is removed following a successful build. Automated builders
|
||||||
|
should be able to build each revision and store the results with no further
|
||||||
|
intervention.
|
245
contrib/depends/funcs.mk
Normal file
245
contrib/depends/funcs.mk
Normal file
@ -0,0 +1,245 @@
|
|||||||
|
define int_vars
|
||||||
|
#Set defaults for vars which may be overridden per-package
|
||||||
|
$(1)_cc=$($($(1)_type)_CC)
|
||||||
|
$(1)_cxx=$($($(1)_type)_CXX)
|
||||||
|
$(1)_objc=$($($(1)_type)_OBJC)
|
||||||
|
$(1)_objcxx=$($($(1)_type)_OBJCXX)
|
||||||
|
$(1)_ar=$($($(1)_type)_AR)
|
||||||
|
$(1)_ranlib=$($($(1)_type)_RANLIB)
|
||||||
|
$(1)_libtool=$($($(1)_type)_LIBTOOL)
|
||||||
|
$(1)_nm=$($($(1)_type)_NM)
|
||||||
|
$(1)_cflags=$($($(1)_type)_CFLAGS) $($($(1)_type)_$(release_type)_CFLAGS)
|
||||||
|
$(1)_cxxflags=$($($(1)_type)_CXXFLAGS) $($($(1)_type)_$(release_type)_CXXFLAGS)
|
||||||
|
$(1)_ldflags=$($($(1)_type)_LDFLAGS) $($($(1)_type)_$(release_type)_LDFLAGS) -L$($($(1)_type)_prefix)/lib
|
||||||
|
$(1)_cppflags=$($($(1)_type)_CPPFLAGS) $($($(1)_type)_$(release_type)_CPPFLAGS) -I$($($(1)_type)_prefix)/include
|
||||||
|
$(1)_recipe_hash:=
|
||||||
|
endef
|
||||||
|
|
||||||
|
define int_get_all_dependencies
|
||||||
|
$(sort $(foreach dep,$(2),$(2) $(call int_get_all_dependencies,$(1),$($(dep)_dependencies))))
|
||||||
|
endef
|
||||||
|
|
||||||
|
define fetch_file_inner
|
||||||
|
( mkdir -p $$($(1)_download_dir) && echo Fetching $(3) from $(2) && \
|
||||||
|
$(build_DOWNLOAD) "$$($(1)_download_dir)/$(4).temp" "$(2)/$(3)" && \
|
||||||
|
echo "$(5) $$($(1)_download_dir)/$(4).temp" > $$($(1)_download_dir)/.$(4).hash && \
|
||||||
|
$(build_SHA256SUM) -c $$($(1)_download_dir)/.$(4).hash && \
|
||||||
|
mv $$($(1)_download_dir)/$(4).temp $$($(1)_source_dir)/$(4) && \
|
||||||
|
rm -rf $$($(1)_download_dir) )
|
||||||
|
endef
|
||||||
|
|
||||||
|
define fetch_file
|
||||||
|
( test -f $$($(1)_source_dir)/$(4) || \
|
||||||
|
( $(call fetch_file_inner,$(1),$(2),$(3),$(4),$(5)) || \
|
||||||
|
$(call fetch_file_inner,$(1),$(FALLBACK_DOWNLOAD_PATH),$(3),$(4),$(5))))
|
||||||
|
endef
|
||||||
|
|
||||||
|
define int_get_build_recipe_hash
|
||||||
|
$(eval $(1)_all_file_checksums:=$(shell $(build_SHA256SUM) $(meta_depends) packages/$(1).mk $(addprefix $(PATCHES_PATH)/$(1)/,$($(1)_patches)) | cut -d" " -f1))
|
||||||
|
$(eval $(1)_recipe_hash:=$(shell echo -n "$($(1)_all_file_checksums)" | $(build_SHA256SUM) | cut -d" " -f1))
|
||||||
|
endef
|
||||||
|
|
||||||
|
define int_get_build_id
|
||||||
|
$(eval $(1)_dependencies += $($(1)_$(host_arch)_$(host_os)_dependencies) $($(1)_$(host_os)_dependencies))
|
||||||
|
$(eval $(1)_all_dependencies:=$(call int_get_all_dependencies,$(1),$($($(1)_type)_native_toolchain) $($(1)_dependencies)))
|
||||||
|
$(foreach dep,$($(1)_all_dependencies),$(eval $(1)_build_id_deps+=$(dep)-$($(dep)_version)-$($(dep)_recipe_hash)))
|
||||||
|
$(eval $(1)_build_id_long:=$(1)-$($(1)_version)-$($(1)_recipe_hash)-$(release_type) $($(1)_build_id_deps) $($($(1)_type)_id_string))
|
||||||
|
$(eval $(1)_build_id:=$(shell echo -n "$($(1)_build_id_long)" | $(build_SHA256SUM) | cut -c-$(HASH_LENGTH)))
|
||||||
|
final_build_id_long+=$($(package)_build_id_long)
|
||||||
|
|
||||||
|
#compute package-specific paths
|
||||||
|
$(1)_build_subdir?=.
|
||||||
|
$(1)_download_file?=$($(1)_file_name)
|
||||||
|
$(1)_source_dir:=$(SOURCES_PATH)
|
||||||
|
$(1)_source:=$$($(1)_source_dir)/$($(1)_file_name)
|
||||||
|
$(1)_staging_dir=$(base_staging_dir)/$(host)/$(1)/$($(1)_version)-$($(1)_build_id)
|
||||||
|
$(1)_staging_prefix_dir:=$$($(1)_staging_dir)$($($(1)_type)_prefix)
|
||||||
|
$(1)_extract_dir:=$(base_build_dir)/$(host)/$(1)/$($(1)_version)-$($(1)_build_id)
|
||||||
|
$(1)_download_dir:=$(base_download_dir)/$(1)-$($(1)_version)
|
||||||
|
$(1)_build_dir:=$$($(1)_extract_dir)/$$($(1)_build_subdir)
|
||||||
|
$(1)_cached_checksum:=$(BASE_CACHE)/$(host)/$(1)/$(1)-$($(1)_version)-$($(1)_build_id).tar.gz.hash
|
||||||
|
$(1)_patch_dir:=$(base_build_dir)/$(host)/$(1)/$($(1)_version)-$($(1)_build_id)/.patches-$($(1)_build_id)
|
||||||
|
$(1)_prefixbin:=$($($(1)_type)_prefix)/bin/
|
||||||
|
$(1)_cached:=$(BASE_CACHE)/$(host)/$(1)/$(1)-$($(1)_version)-$($(1)_build_id).tar.gz
|
||||||
|
$(1)_all_sources=$($(1)_file_name) $($(1)_extra_sources)
|
||||||
|
|
||||||
|
#stamps
|
||||||
|
$(1)_fetched=$(SOURCES_PATH)/download-stamps/.stamp_fetched-$(1)-$($(1)_file_name).hash
|
||||||
|
$(1)_extracted=$$($(1)_extract_dir)/.stamp_extracted
|
||||||
|
$(1)_preprocessed=$$($(1)_extract_dir)/.stamp_preprocessed
|
||||||
|
$(1)_cleaned=$$($(1)_extract_dir)/.stamp_cleaned
|
||||||
|
$(1)_built=$$($(1)_build_dir)/.stamp_built
|
||||||
|
$(1)_configured=$$($(1)_build_dir)/.stamp_configured
|
||||||
|
$(1)_staged=$$($(1)_staging_dir)/.stamp_staged
|
||||||
|
$(1)_postprocessed=$$($(1)_staging_prefix_dir)/.stamp_postprocessed
|
||||||
|
$(1)_download_path_fixed=$(subst :,\:,$$($(1)_download_path))
|
||||||
|
|
||||||
|
|
||||||
|
#default commands
|
||||||
|
$(1)_fetch_cmds ?= $(call fetch_file,$(1),$(subst \:,:,$$($(1)_download_path_fixed)),$$($(1)_download_file),$($(1)_file_name),$($(1)_sha256_hash))
|
||||||
|
$(1)_extract_cmds ?= mkdir -p $$($(1)_extract_dir) && echo "$$($(1)_sha256_hash) $$($(1)_source)" > $$($(1)_extract_dir)/.$$($(1)_file_name).hash && $(build_SHA256SUM) -c $$($(1)_extract_dir)/.$$($(1)_file_name).hash && tar --strip-components=1 -xf $$($(1)_source)
|
||||||
|
$(1)_preprocess_cmds ?=
|
||||||
|
$(1)_build_cmds ?=
|
||||||
|
$(1)_config_cmds ?=
|
||||||
|
$(1)_stage_cmds ?=
|
||||||
|
$(1)_set_vars ?=
|
||||||
|
|
||||||
|
|
||||||
|
all_sources+=$$($(1)_fetched)
|
||||||
|
endef
|
||||||
|
#$(foreach dep_target,$($(1)_all_dependencies),$(eval $(1)_dependency_targets=$($(dep_target)_cached)))
|
||||||
|
|
||||||
|
|
||||||
|
define int_config_attach_build_config
|
||||||
|
$(eval $(call $(1)_set_vars,$(1)))
|
||||||
|
$(1)_cflags+=$($(1)_cflags_$(release_type))
|
||||||
|
$(1)_cflags+=$($(1)_cflags_$(host_arch)) $($(1)_cflags_$(host_arch)_$(release_type))
|
||||||
|
$(1)_cflags+=$($(1)_cflags_$(host_os)) $($(1)_cflags_$(host_os)_$(release_type))
|
||||||
|
$(1)_cflags+=$($(1)_cflags_$(host_arch)_$(host_os)) $($(1)_cflags_$(host_arch)_$(host_os)_$(release_type))
|
||||||
|
|
||||||
|
$(1)_cxxflags+=$($(1)_cxxflags_$(release_type))
|
||||||
|
$(1)_cxxflags+=$($(1)_cxxflags_$(host_arch)) $($(1)_cxxflags_$(host_arch)_$(release_type))
|
||||||
|
$(1)_cxxflags+=$($(1)_cxxflags_$(host_os)) $($(1)_cxxflags_$(host_os)_$(release_type))
|
||||||
|
$(1)_cxxflags+=$($(1)_cxxflags_$(host_arch)_$(host_os)) $($(1)_cxxflags_$(host_arch)_$(host_os)_$(release_type))
|
||||||
|
|
||||||
|
$(1)_cppflags+=$($(1)_cppflags_$(release_type))
|
||||||
|
$(1)_cppflags+=$($(1)_cppflags_$(host_arch)) $($(1)_cppflags_$(host_arch)_$(release_type))
|
||||||
|
$(1)_cppflags+=$($(1)_cppflags_$(host_os)) $($(1)_cppflags_$(host_os)_$(release_type))
|
||||||
|
$(1)_cppflags+=$($(1)_cppflags_$(host_arch)_$(host_os)) $($(1)_cppflags_$(host_arch)_$(host_os)_$(release_type))
|
||||||
|
|
||||||
|
$(1)_ldflags+=$($(1)_ldflags_$(release_type))
|
||||||
|
$(1)_ldflags+=$($(1)_ldflags_$(host_arch)) $($(1)_ldflags_$(host_arch)_$(release_type))
|
||||||
|
$(1)_ldflags+=$($(1)_ldflags_$(host_os)) $($(1)_ldflags_$(host_os)_$(release_type))
|
||||||
|
$(1)_ldflags+=$($(1)_ldflags_$(host_arch)_$(host_os)) $($(1)_ldflags_$(host_arch)_$(host_os)_$(release_type))
|
||||||
|
|
||||||
|
$(1)_build_opts+=$$($(1)_build_opts_$(release_type))
|
||||||
|
$(1)_build_opts+=$$($(1)_build_opts_$(host_arch)) $$($(1)_build_opts_$(host_arch)_$(release_type))
|
||||||
|
$(1)_build_opts+=$$($(1)_build_opts_$(host_os)) $$($(1)_build_opts_$(host_os)_$(release_type))
|
||||||
|
$(1)_build_opts+=$$($(1)_build_opts_$(host_arch)_$(host_os)) $$($(1)_build_opts_$(host_arch)_$(host_os)_$(release_type))
|
||||||
|
|
||||||
|
$(1)_config_opts+=$$($(1)_config_opts_$(release_type))
|
||||||
|
$(1)_config_opts+=$$($(1)_config_opts_$(host_arch)) $$($(1)_config_opts_$(host_arch)_$(release_type))
|
||||||
|
$(1)_config_opts+=$$($(1)_config_opts_$(host_os)) $$($(1)_config_opts_$(host_os)_$(release_type))
|
||||||
|
$(1)_config_opts+=$$($(1)_config_opts_$(host_arch)_$(host_os)) $$($(1)_config_opts_$(host_arch)_$(host_os)_$(release_type))
|
||||||
|
|
||||||
|
$(1)_config_env+=$$($(1)_config_env_$(release_type))
|
||||||
|
$(1)_config_env+=$($(1)_config_env_$(host_arch)) $($(1)_config_env_$(host_arch)_$(release_type))
|
||||||
|
$(1)_config_env+=$($(1)_config_env_$(host_os)) $($(1)_config_env_$(host_os)_$(release_type))
|
||||||
|
$(1)_config_env+=$($(1)_config_env_$(host_arch)_$(host_os)) $($(1)_config_env_$(host_arch)_$(host_os)_$(release_type))
|
||||||
|
|
||||||
|
$(1)_config_env+=PKG_CONFIG_LIBDIR=$($($(1)_type)_prefix)/lib/pkgconfig
|
||||||
|
$(1)_config_env+=PKG_CONFIG_PATH=$($($(1)_type)_prefix)/share/pkgconfig
|
||||||
|
$(1)_config_env+=PATH=$(build_prefix)/bin:$(PATH)
|
||||||
|
$(1)_build_env+=PATH=$(build_prefix)/bin:$(PATH)
|
||||||
|
$(1)_stage_env+=PATH=$(build_prefix)/bin:$(PATH)
|
||||||
|
$(1)_autoconf=./configure --host=$($($(1)_type)_host) --disable-dependency-tracking --prefix=$($($(1)_type)_prefix) $$($(1)_config_opts) CC="$$($(1)_cc)" CXX="$$($(1)_cxx)"
|
||||||
|
|
||||||
|
ifneq ($($(1)_nm),)
|
||||||
|
$(1)_autoconf += NM="$$($(1)_nm)"
|
||||||
|
endif
|
||||||
|
ifneq ($($(1)_ranlib),)
|
||||||
|
$(1)_autoconf += RANLIB="$$($(1)_ranlib)"
|
||||||
|
endif
|
||||||
|
ifneq ($($(1)_ar),)
|
||||||
|
$(1)_autoconf += AR="$$($(1)_ar)"
|
||||||
|
endif
|
||||||
|
ifneq ($($(1)_cflags),)
|
||||||
|
$(1)_autoconf += CFLAGS="$$($(1)_cflags)"
|
||||||
|
endif
|
||||||
|
ifneq ($($(1)_cxxflags),)
|
||||||
|
$(1)_autoconf += CXXFLAGS="$$($(1)_cxxflags)"
|
||||||
|
endif
|
||||||
|
ifneq ($($(1)_cppflags),)
|
||||||
|
$(1)_autoconf += CPPFLAGS="$$($(1)_cppflags)"
|
||||||
|
endif
|
||||||
|
ifneq ($($(1)_ldflags),)
|
||||||
|
$(1)_autoconf += LDFLAGS="$$($(1)_ldflags)"
|
||||||
|
endif
|
||||||
|
endef
|
||||||
|
|
||||||
|
define int_add_cmds
|
||||||
|
$($(1)_fetched):
|
||||||
|
$(AT)mkdir -p $$(@D) $(SOURCES_PATH)
|
||||||
|
$(AT)rm -f $$@
|
||||||
|
$(AT)touch $$@
|
||||||
|
$(AT)cd $$(@D); $(call $(1)_fetch_cmds,$(1))
|
||||||
|
$(AT)cd $($(1)_source_dir); $(foreach source,$($(1)_all_sources),$(build_SHA256SUM) $(source) >> $$(@);)
|
||||||
|
$(AT)touch $$@
|
||||||
|
$($(1)_extracted): | $($(1)_fetched)
|
||||||
|
$(AT)echo Extracting $(1)...
|
||||||
|
$(AT)mkdir -p $$(@D)
|
||||||
|
$(AT)cd $$(@D); $(call $(1)_extract_cmds,$(1))
|
||||||
|
$(AT)touch $$@
|
||||||
|
$($(1)_preprocessed): | $($(1)_dependencies) $($(1)_extracted)
|
||||||
|
$(AT)echo Preprocessing $(1)...
|
||||||
|
$(AT)mkdir -p $$(@D) $($(1)_patch_dir)
|
||||||
|
$(AT)$(foreach patch,$($(1)_patches),cd $(PATCHES_PATH)/$(1); cp $(patch) $($(1)_patch_dir) ;)
|
||||||
|
$(AT)cd $$(@D); $(call $(1)_preprocess_cmds, $(1))
|
||||||
|
$(AT)touch $$@
|
||||||
|
$($(1)_configured): | $($(1)_preprocessed)
|
||||||
|
$(AT)echo Configuring $(1)...
|
||||||
|
$(AT)rm -rf $(host_prefix); mkdir -p $(host_prefix)/lib; cd $(host_prefix); $(foreach package,$($(1)_all_dependencies), tar xf $($(package)_cached); )
|
||||||
|
$(AT)mkdir -p $$(@D)
|
||||||
|
$(AT)+cd $$(@D); $($(1)_config_env) $(call $(1)_config_cmds, $(1))
|
||||||
|
$(AT)touch $$@
|
||||||
|
$($(1)_built): | $($(1)_configured)
|
||||||
|
$(AT)echo Building $(1)...
|
||||||
|
$(AT)mkdir -p $$(@D)
|
||||||
|
$(AT)+cd $$(@D); $($(1)_build_env) $(call $(1)_build_cmds, $(1))
|
||||||
|
$(AT)touch $$@
|
||||||
|
$($(1)_staged): | $($(1)_built)
|
||||||
|
$(AT)echo Staging $(1)...
|
||||||
|
$(AT)mkdir -p $($(1)_staging_dir)/$(host_prefix)
|
||||||
|
$(AT)cd $($(1)_build_dir); $($(1)_stage_env) $(call $(1)_stage_cmds, $(1))
|
||||||
|
$(AT)rm -rf $($(1)_extract_dir)
|
||||||
|
$(AT)touch $$@
|
||||||
|
$($(1)_postprocessed): | $($(1)_staged)
|
||||||
|
$(AT)echo Postprocessing $(1)...
|
||||||
|
$(AT)cd $($(1)_staging_prefix_dir); $(call $(1)_postprocess_cmds)
|
||||||
|
$(AT)touch $$@
|
||||||
|
$($(1)_cached): | $($(1)_dependencies) $($(1)_postprocessed)
|
||||||
|
$(AT)echo Caching $(1)...
|
||||||
|
$(AT)cd $$($(1)_staging_dir)/$(host_prefix); find . | sort | tar --no-recursion -czf $$($(1)_staging_dir)/$$(@F) -T -
|
||||||
|
$(AT)mkdir -p $$(@D)
|
||||||
|
$(AT)rm -rf $$(@D) && mkdir -p $$(@D)
|
||||||
|
$(AT)mv $$($(1)_staging_dir)/$$(@F) $$(@)
|
||||||
|
$(AT)rm -rf $($(1)_staging_dir)
|
||||||
|
$($(1)_cached_checksum): $($(1)_cached)
|
||||||
|
$(AT)cd $$(@D); $(build_SHA256SUM) $$(<F) > $$(@)
|
||||||
|
|
||||||
|
.PHONY: $(1)
|
||||||
|
$(1): | $($(1)_cached_checksum)
|
||||||
|
.SECONDARY: $($(1)_cached) $($(1)_postprocessed) $($(1)_staged) $($(1)_built) $($(1)_configured) $($(1)_preprocessed) $($(1)_extracted) $($(1)_fetched)
|
||||||
|
|
||||||
|
endef
|
||||||
|
|
||||||
|
# These functions create the build targets for each package. They must be
|
||||||
|
# broken down into small steps so that each part is done for all packages
|
||||||
|
# before moving on to the next step. Otherwise, a package's info
|
||||||
|
# (build-id for example) would only be available to another package if it
|
||||||
|
# happened to be computed already.
|
||||||
|
|
||||||
|
#set the type for host/build packages.
|
||||||
|
$(foreach native_package,$(native_packages),$(eval $(native_package)_type=build))
|
||||||
|
$(foreach package,$(packages),$(eval $(package)_type=$(host_arch)_$(host_os)))
|
||||||
|
|
||||||
|
#set overridable defaults
|
||||||
|
$(foreach package,$(all_packages),$(eval $(call int_vars,$(package))))
|
||||||
|
|
||||||
|
#include package files
|
||||||
|
$(foreach package,$(all_packages),$(eval include packages/$(package).mk))
|
||||||
|
|
||||||
|
#compute a hash of all files that comprise this package's build recipe
|
||||||
|
$(foreach package,$(all_packages),$(eval $(call int_get_build_recipe_hash,$(package))))
|
||||||
|
|
||||||
|
#generate a unique id for this package, incorporating its dependencies as well
|
||||||
|
$(foreach package,$(all_packages),$(eval $(call int_get_build_id,$(package))))
|
||||||
|
|
||||||
|
#compute final vars after reading package vars
|
||||||
|
$(foreach package,$(all_packages),$(eval $(call int_config_attach_build_config,$(package))))
|
||||||
|
|
||||||
|
#create build targets
|
||||||
|
$(foreach package,$(all_packages),$(eval $(call int_add_cmds,$(package))))
|
||||||
|
|
||||||
|
#special exception: if a toolchain package exists, all non-native packages depend on it
|
||||||
|
$(foreach package,$(packages),$(eval $($(package)_unpacked): |$($($(host_arch)_$(host_os)_native_toolchain)_cached) ))
|
17
contrib/depends/hosts/darwin.mk
Normal file
17
contrib/depends/hosts/darwin.mk
Normal file
@ -0,0 +1,17 @@
|
|||||||
|
OSX_MIN_VERSION=10.8
|
||||||
|
OSX_SDK_VERSION=10.11
|
||||||
|
OSX_SDK=$(SDK_PATH)/MacOSX$(OSX_SDK_VERSION).sdk
|
||||||
|
LD64_VERSION=253.9
|
||||||
|
darwin_CC=clang -target $(host) -mmacosx-version-min=$(OSX_MIN_VERSION) --sysroot $(OSX_SDK) -mlinker-version=$(LD64_VERSION)
|
||||||
|
darwin_CXX=clang++ -target $(host) -mmacosx-version-min=$(OSX_MIN_VERSION) --sysroot $(OSX_SDK) -mlinker-version=$(LD64_VERSION) -stdlib=libc++
|
||||||
|
|
||||||
|
darwin_CFLAGS=-pipe
|
||||||
|
darwin_CXXFLAGS=$(darwin_CFLAGS)
|
||||||
|
|
||||||
|
darwin_release_CFLAGS=-O2
|
||||||
|
darwin_release_CXXFLAGS=$(darwin_release_CFLAGS)
|
||||||
|
|
||||||
|
darwin_debug_CFLAGS=-O1
|
||||||
|
darwin_debug_CXXFLAGS=$(darwin_debug_CFLAGS)
|
||||||
|
|
||||||
|
darwin_native_toolchain=native_cctools
|
26
contrib/depends/hosts/default.mk
Normal file
26
contrib/depends/hosts/default.mk
Normal file
@ -0,0 +1,26 @@
|
|||||||
|
default_host_CC = $(host_toolchain)gcc
|
||||||
|
default_host_CXX = $(host_toolchain)g++
|
||||||
|
default_host_AR = $(host_toolchain)ar
|
||||||
|
default_host_RANLIB = $(host_toolchain)ranlib
|
||||||
|
default_host_STRIP = $(host_toolchain)strip
|
||||||
|
default_host_LIBTOOL = $(host_toolchain)libtool
|
||||||
|
default_host_INSTALL_NAME_TOOL = $(host_toolchain)install_name_tool
|
||||||
|
default_host_OTOOL = $(host_toolchain)otool
|
||||||
|
default_host_NM = $(host_toolchain)nm
|
||||||
|
|
||||||
|
define add_host_tool_func
|
||||||
|
$(host_os)_$1?=$$(default_host_$1)
|
||||||
|
$(host_arch)_$(host_os)_$1?=$$($(host_os)_$1)
|
||||||
|
$(host_arch)_$(host_os)_$(release_type)_$1?=$$($(host_os)_$1)
|
||||||
|
host_$1=$$($(host_arch)_$(host_os)_$1)
|
||||||
|
endef
|
||||||
|
|
||||||
|
define add_host_flags_func
|
||||||
|
$(host_arch)_$(host_os)_$1 += $($(host_os)_$1)
|
||||||
|
$(host_arch)_$(host_os)_$(release_type)_$1 += $($(host_os)_$(release_type)_$1)
|
||||||
|
host_$1 = $$($(host_arch)_$(host_os)_$1)
|
||||||
|
host_$(release_type)_$1 = $$($(host_arch)_$(host_os)_$(release_type)_$1)
|
||||||
|
endef
|
||||||
|
|
||||||
|
$(foreach tool,CC CXX AR RANLIB STRIP NM LIBTOOL OTOOL INSTALL_NAME_TOOL,$(eval $(call add_host_tool_func,$(tool))))
|
||||||
|
$(foreach flags,CFLAGS CXXFLAGS CPPFLAGS LDFLAGS, $(eval $(call add_host_flags_func,$(flags))))
|
31
contrib/depends/hosts/linux.mk
Normal file
31
contrib/depends/hosts/linux.mk
Normal file
@ -0,0 +1,31 @@
|
|||||||
|
linux_CFLAGS=-pipe
|
||||||
|
linux_CXXFLAGS=$(linux_CFLAGS)
|
||||||
|
|
||||||
|
linux_release_CFLAGS=-O2
|
||||||
|
linux_release_CXXFLAGS=$(linux_release_CFLAGS)
|
||||||
|
|
||||||
|
linux_debug_CFLAGS=-O1
|
||||||
|
linux_debug_CXXFLAGS=$(linux_debug_CFLAGS)
|
||||||
|
|
||||||
|
linux_debug_CPPFLAGS=-D_GLIBCXX_DEBUG -D_GLIBCXX_DEBUG_PEDANTIC
|
||||||
|
|
||||||
|
ifeq (86,$(findstring 86,$(build_arch)))
|
||||||
|
i686_linux_CC=gcc -m32
|
||||||
|
i686_linux_CXX=g++ -m32
|
||||||
|
i686_linux_AR=ar
|
||||||
|
i686_linux_RANLIB=ranlib
|
||||||
|
i686_linux_NM=nm
|
||||||
|
i686_linux_STRIP=strip
|
||||||
|
|
||||||
|
x86_64_linux_CC=gcc -m64
|
||||||
|
x86_64_linux_CXX=g++ -m64
|
||||||
|
x86_64_linux_AR=ar
|
||||||
|
x86_64_linux_RANLIB=ranlib
|
||||||
|
x86_64_linux_NM=nm
|
||||||
|
x86_64_linux_STRIP=strip
|
||||||
|
else
|
||||||
|
i686_linux_CC=$(default_host_CC) -m32
|
||||||
|
i686_linux_CXX=$(default_host_CXX) -m32
|
||||||
|
x86_64_linux_CC=$(default_host_CC) -m64
|
||||||
|
x86_64_linux_CXX=$(default_host_CXX) -m64
|
||||||
|
endif
|
10
contrib/depends/hosts/mingw32.mk
Normal file
10
contrib/depends/hosts/mingw32.mk
Normal file
@ -0,0 +1,10 @@
|
|||||||
|
mingw32_CFLAGS=-pipe
|
||||||
|
mingw32_CXXFLAGS=$(mingw32_CFLAGS)
|
||||||
|
|
||||||
|
mingw32_release_CFLAGS=-O2
|
||||||
|
mingw32_release_CXXFLAGS=$(mingw32_release_CFLAGS)
|
||||||
|
|
||||||
|
mingw32_debug_CFLAGS=-O1
|
||||||
|
mingw32_debug_CXXFLAGS=$(mingw32_debug_CFLAGS)
|
||||||
|
|
||||||
|
mingw32_debug_CPPFLAGS=-D_GLIBCXX_DEBUG -D_GLIBCXX_DEBUG_PEDANTIC
|
147
contrib/depends/packages.md
Normal file
147
contrib/depends/packages.md
Normal file
@ -0,0 +1,147 @@
|
|||||||
|
Each recipe consists of 3 main parts: defining identifiers, setting build
|
||||||
|
variables, and defining build commands.
|
||||||
|
|
||||||
|
The package "mylib" will be used here as an example
|
||||||
|
|
||||||
|
General tips:
|
||||||
|
- mylib_foo is written as $(package)_foo in order to make recipes more similar.
|
||||||
|
|
||||||
|
## Identifiers
|
||||||
|
Each package is required to define at least these variables:
|
||||||
|
|
||||||
|
$(package)_version:
|
||||||
|
Version of the upstream library or program. If there is no version, a
|
||||||
|
placeholder such as 1.0 can be used.
|
||||||
|
|
||||||
|
$(package)_download_path:
|
||||||
|
Location of the upstream source, without the file-name. Usually http or
|
||||||
|
ftp.
|
||||||
|
|
||||||
|
$(package)_file_name:
|
||||||
|
The upstream source filename available at the download path.
|
||||||
|
|
||||||
|
$(package)_sha256_hash:
|
||||||
|
The sha256 hash of the upstream file
|
||||||
|
|
||||||
|
These variables are optional:
|
||||||
|
|
||||||
|
$(package)_build_subdir:
|
||||||
|
cd to this dir before running configure/build/stage commands.
|
||||||
|
|
||||||
|
$(package)_download_file:
|
||||||
|
The file-name of the upstream source if it differs from how it should be
|
||||||
|
stored locally. This can be used to avoid storing file-names with strange
|
||||||
|
characters.
|
||||||
|
|
||||||
|
$(package)_dependencies:
|
||||||
|
Names of any other packages that this one depends on.
|
||||||
|
|
||||||
|
$(package)_patches:
|
||||||
|
Filenames of any patches needed to build the package
|
||||||
|
|
||||||
|
$(package)_extra_sources:
|
||||||
|
Any extra files that will be fetched via $(package)_fetch_cmds. These are
|
||||||
|
specified so that they can be fetched and verified via 'make download'.
|
||||||
|
|
||||||
|
|
||||||
|
## Build Variables:
|
||||||
|
After defining the main identifiers, build variables may be added or customized
|
||||||
|
before running the build commands. They should be added to a function called
|
||||||
|
$(package)_set_vars. For example:
|
||||||
|
|
||||||
|
define $(package)_set_vars
|
||||||
|
...
|
||||||
|
endef
|
||||||
|
|
||||||
|
Most variables can be prefixed with the host, architecture, or both, to make
|
||||||
|
the modifications specific to that case. For example:
|
||||||
|
|
||||||
|
Universal: $(package)_cc=gcc
|
||||||
|
Linux only: $(package)_linux_cc=gcc
|
||||||
|
x86_64 only: $(package)_x86_64_cc = gcc
|
||||||
|
x86_64 linux only: $(package)_x86_64_linux_cc = gcc
|
||||||
|
|
||||||
|
These variables may be set to override or append their default values.
|
||||||
|
|
||||||
|
$(package)_cc
|
||||||
|
$(package)_cxx
|
||||||
|
$(package)_objc
|
||||||
|
$(package)_objcxx
|
||||||
|
$(package)_ar
|
||||||
|
$(package)_ranlib
|
||||||
|
$(package)_libtool
|
||||||
|
$(package)_nm
|
||||||
|
$(package)_cflags
|
||||||
|
$(package)_cxxflags
|
||||||
|
$(package)_ldflags
|
||||||
|
$(package)_cppflags
|
||||||
|
$(package)_config_env
|
||||||
|
$(package)_build_env
|
||||||
|
$(package)_stage_env
|
||||||
|
$(package)_build_opts
|
||||||
|
$(package)_config_opts
|
||||||
|
|
||||||
|
The *_env variables are used to add environment variables to the respective
|
||||||
|
commands.
|
||||||
|
|
||||||
|
Many variables respect a debug/release suffix as well, in order to use them for
|
||||||
|
only the appropriate build config. For example:
|
||||||
|
|
||||||
|
$(package)_cflags_release = -O3
|
||||||
|
$(package)_cflags_i686_debug = -g
|
||||||
|
$(package)_config_opts_release = --disable-debug
|
||||||
|
|
||||||
|
These will be used in addition to the options that do not specify
|
||||||
|
debug/release. All builds are considered to be release unless DEBUG=1 is set by
|
||||||
|
the user. Other variables may be defined as needed.
|
||||||
|
|
||||||
|
## Build commands:
|
||||||
|
|
||||||
|
For each build, a unique build dir and staging dir are created. For example,
|
||||||
|
`work/build/mylib/1.0-1adac830f6e` and `work/staging/mylib/1.0-1adac830f6e`.
|
||||||
|
|
||||||
|
The following build commands are available for each recipe:
|
||||||
|
|
||||||
|
$(package)_fetch_cmds:
|
||||||
|
Runs from: build dir
|
||||||
|
Fetch the source file. If undefined, it will be fetched and verified
|
||||||
|
against its hash.
|
||||||
|
|
||||||
|
$(package)_extract_cmds:
|
||||||
|
Runs from: build dir
|
||||||
|
Verify the source file against its hash and extract it. If undefined, the
|
||||||
|
source is assumed to be a tarball.
|
||||||
|
|
||||||
|
$(package)_preprocess_cmds:
|
||||||
|
Runs from: build dir/$(package)_build_subdir
|
||||||
|
Preprocess the source as necessary. If undefined, does nothing.
|
||||||
|
|
||||||
|
$(package)_config_cmds:
|
||||||
|
Runs from: build dir/$(package)_build_subdir
|
||||||
|
Configure the source. If undefined, does nothing.
|
||||||
|
|
||||||
|
$(package)_build_cmds:
|
||||||
|
Runs from: build dir/$(package)_build_subdir
|
||||||
|
Build the source. If undefined, does nothing.
|
||||||
|
|
||||||
|
$(package)_stage_cmds:
|
||||||
|
Runs from: build dir/$(package)_build_subdir
|
||||||
|
Stage the build results. If undefined, does nothing.
|
||||||
|
|
||||||
|
The following variables are available for each recipe:
|
||||||
|
|
||||||
|
$(1)_staging_dir: package's destination sysroot path
|
||||||
|
$(1)_staging_prefix_dir: prefix path inside of the package's staging dir
|
||||||
|
$(1)_extract_dir: path to the package's extracted sources
|
||||||
|
$(1)_build_dir: path where configure/build/stage commands will be run
|
||||||
|
$(1)_patch_dir: path where the package's patches (if any) are found
|
||||||
|
|
||||||
|
Notes on build commands:
|
||||||
|
|
||||||
|
For packages built with autotools, $($(package)_autoconf) can be used in the
|
||||||
|
configure step to (usually) correctly configure automatically. Any
|
||||||
|
$($(package)_config_opts) will be appended.
|
||||||
|
|
||||||
|
Most autotools projects can be properly staged using:
|
||||||
|
|
||||||
|
$(MAKE) DESTDIR=$($(package)_staging_dir) install
|
31
contrib/depends/packages/bdb.mk
Normal file
31
contrib/depends/packages/bdb.mk
Normal file
@ -0,0 +1,31 @@
|
|||||||
|
package=bdb
|
||||||
|
$(package)_version=4.8.30
|
||||||
|
$(package)_download_path=http://download.oracle.com/berkeley-db
|
||||||
|
$(package)_file_name=db-$($(package)_version).NC.tar.gz
|
||||||
|
$(package)_sha256_hash=12edc0df75bf9abd7f82f821795bcee50f42cb2e5f76a6a281b85732798364ef
|
||||||
|
$(package)_build_subdir=build_unix
|
||||||
|
|
||||||
|
define $(package)_set_vars
|
||||||
|
$(package)_config_opts=--disable-shared --enable-cxx --disable-replication
|
||||||
|
$(package)_config_opts_mingw32=--enable-mingw
|
||||||
|
$(package)_config_opts_linux=--with-pic
|
||||||
|
$(package)_cxxflags=-std=c++11
|
||||||
|
endef
|
||||||
|
|
||||||
|
define $(package)_preprocess_cmds
|
||||||
|
sed -i.old 's/__atomic_compare_exchange/__atomic_compare_exchange_db/' dbinc/atomic.h && \
|
||||||
|
sed -i.old 's/atomic_init/atomic_init_db/' dbinc/atomic.h mp/mp_region.c mp/mp_mvcc.c mp/mp_fget.c mutex/mut_method.c mutex/mut_tas.c && \
|
||||||
|
cp -f $(BASEDIR)/config.guess $(BASEDIR)/config.sub dist
|
||||||
|
endef
|
||||||
|
|
||||||
|
define $(package)_config_cmds
|
||||||
|
../dist/$($(package)_autoconf)
|
||||||
|
endef
|
||||||
|
|
||||||
|
define $(package)_build_cmds
|
||||||
|
$(MAKE) libdb_cxx-4.8.a libdb-4.8.a
|
||||||
|
endef
|
||||||
|
|
||||||
|
define $(package)_stage_cmds
|
||||||
|
$(MAKE) DESTDIR=$($(package)_staging_dir) install_lib install_include
|
||||||
|
endef
|
41
contrib/depends/packages/boost.mk
Normal file
41
contrib/depends/packages/boost.mk
Normal file
@ -0,0 +1,41 @@
|
|||||||
|
package=boost
|
||||||
|
$(package)_version=1_64_0
|
||||||
|
$(package)_download_path=https://dl.bintray.com/boostorg/release/1.64.0/source/
|
||||||
|
$(package)_file_name=$(package)_$($(package)_version).tar.bz2
|
||||||
|
$(package)_sha256_hash=7bcc5caace97baa948931d712ea5f37038dbb1c5d89b43ad4def4ed7cb683332
|
||||||
|
|
||||||
|
define $(package)_set_vars
|
||||||
|
$(package)_config_opts_release=variant=release
|
||||||
|
$(package)_config_opts_debug=variant=debug
|
||||||
|
$(package)_config_opts=--layout=tagged --build-type=complete --user-config=user-config.jam
|
||||||
|
$(package)_config_opts+=threading=multi link=static -sNO_BZIP2=1 -sNO_ZLIB=1
|
||||||
|
$(package)_config_opts_linux=threadapi=pthread runtime-link=shared
|
||||||
|
$(package)_config_opts_darwin=--toolset=darwin-4.2.1 runtime-link=shared
|
||||||
|
$(package)_config_opts_mingw32=binary-format=pe target-os=windows threadapi=win32 runtime-link=static
|
||||||
|
$(package)_config_opts_x86_64_mingw32=address-model=64
|
||||||
|
$(package)_config_opts_i686_mingw32=address-model=32
|
||||||
|
$(package)_config_opts_i686_linux=address-model=32 architecture=x86
|
||||||
|
$(package)_toolset_$(host_os)=gcc
|
||||||
|
$(package)_archiver_$(host_os)=$($(package)_ar)
|
||||||
|
$(package)_toolset_darwin=darwin
|
||||||
|
$(package)_archiver_darwin=$($(package)_libtool)
|
||||||
|
$(package)_config_libraries=chrono,filesystem,program_options,system,thread,test,date_time,regex,serialization,locale
|
||||||
|
$(package)_cxxflags=-std=c++11 -fvisibility=hidden
|
||||||
|
$(package)_cxxflags_linux=-fPIC
|
||||||
|
endef
|
||||||
|
|
||||||
|
define $(package)_preprocess_cmds
|
||||||
|
echo "using $(boost_toolset_$(host_os)) : : $($(package)_cxx) : <cxxflags>\"$($(package)_cxxflags) $($(package)_cppflags)\" <linkflags>\"$($(package)_ldflags)\" <archiver>\"$(boost_archiver_$(host_os))\" <striper>\"$(host_STR IP)\" <ranlib>\"$(host_RANLIB)\" <rc>\"$(host_WINDRES)\" : ;" > user-config.jam
|
||||||
|
endef
|
||||||
|
|
||||||
|
define $(package)_config_cmds
|
||||||
|
./bootstrap.sh --without-icu --with-libraries=$(boost_config_libraries)
|
||||||
|
endef
|
||||||
|
|
||||||
|
define $(package)_build_cmds
|
||||||
|
./b2 -d2 -j2 -d1 --prefix=$($(package)_staging_prefix_dir) $($(package)_config_opts) stage
|
||||||
|
endef
|
||||||
|
|
||||||
|
define $(package)_stage_cmds
|
||||||
|
./b2 -d0 -j4 --prefix=$($(package)_staging_prefix_dir) $($(package)_config_opts) install
|
||||||
|
endef
|
67
contrib/depends/packages/cmake/conf/mxe-conf.cmake.in
Normal file
67
contrib/depends/packages/cmake/conf/mxe-conf.cmake.in
Normal file
@ -0,0 +1,67 @@
|
|||||||
|
# This file is part of MXE. See LICENSE.md for licensing information.
|
||||||
|
|
||||||
|
# https://cmake.org/cmake/help/latest
|
||||||
|
|
||||||
|
# Can't set `cmake_minimum_required` or `cmake_policy` in toolchain
|
||||||
|
# since toolchain is read before CMakeLists.txt
|
||||||
|
# See `target-cmake.in` for CMAKE_POLICY_DEFAULT_CMPNNNN
|
||||||
|
|
||||||
|
# Check if we are using mxe supplied version
|
||||||
|
# - toolchain is included multiple times so set a guard in
|
||||||
|
# environment to suppress duplicate messages
|
||||||
|
if(NOT ${CMAKE_COMMAND} STREQUAL @PREFIX@/@BUILD@/bin/cmake AND NOT DEFINED ENV{_MXE_CMAKE_TOOLCHAIN_INCLUDED})
|
||||||
|
message(WARNING "
|
||||||
|
** Warning: direct use of toolchain file is deprecated
|
||||||
|
** Please use prefixed wrapper script instead:
|
||||||
|
@TARGET@-cmake [options] <path-to-source>
|
||||||
|
- uses mxe supplied cmake version @CMAKE_VERSION@
|
||||||
|
- loads toolchain
|
||||||
|
- loads common run results
|
||||||
|
- sets various policy defaults
|
||||||
|
")
|
||||||
|
set(ENV{_MXE_CMAKE_TOOLCHAIN_INCLUDED} TRUE)
|
||||||
|
endif()
|
||||||
|
|
||||||
|
## General configuration
|
||||||
|
set(CMAKE_SYSTEM_NAME Windows)
|
||||||
|
set(MSYS 1)
|
||||||
|
set(CMAKE_EXPORT_NO_PACKAGE_REGISTRY ON)
|
||||||
|
# Workaround for https://www.cmake.org/Bug/view.php?id=14075
|
||||||
|
set(CMAKE_CROSS_COMPILING ON)
|
||||||
|
|
||||||
|
|
||||||
|
## Library config
|
||||||
|
set(BUILD_SHARED_LIBS @CMAKE_SHARED_BOOL@ CACHE BOOL "BUILD_SHARED_LIBS" FORCE)
|
||||||
|
set(BUILD_STATIC_LIBS @CMAKE_STATIC_BOOL@ CACHE BOOL "BUILD_STATIC_LIBS" FORCE)
|
||||||
|
set(BUILD_SHARED @CMAKE_SHARED_BOOL@ CACHE BOOL "BUILD_SHARED" FORCE)
|
||||||
|
set(BUILD_STATIC @CMAKE_STATIC_BOOL@ CACHE BOOL "BUILD_STATIC" FORCE)
|
||||||
|
set(LIBTYPE @LIBTYPE@)
|
||||||
|
|
||||||
|
|
||||||
|
## Paths etc.
|
||||||
|
set(CMAKE_FIND_ROOT_PATH @PREFIX@/@TARGET@)
|
||||||
|
set(CMAKE_FIND_ROOT_PATH_MODE_PROGRAM NEVER)
|
||||||
|
set(CMAKE_FIND_ROOT_PATH_MODE_INCLUDE ONLY)
|
||||||
|
set(CMAKE_FIND_ROOT_PATH_MODE_LIBRARY ONLY)
|
||||||
|
set(CMAKE_PREFIX_PATH @PREFIX@/@TARGET@)
|
||||||
|
set(CMAKE_INSTALL_PREFIX @PREFIX@/@TARGET@ CACHE PATH "Installation Prefix")
|
||||||
|
# For custom mxe FindPackage scripts
|
||||||
|
set(CMAKE_MODULE_PATH "@PREFIX@/share/cmake/modules" ${CMAKE_MODULE_PATH})
|
||||||
|
|
||||||
|
|
||||||
|
## Programs
|
||||||
|
set(CMAKE_C_COMPILER @PREFIX@/bin/@TARGET@-gcc)
|
||||||
|
set(CMAKE_CXX_COMPILER @PREFIX@/bin/@TARGET@-g++)
|
||||||
|
set(CMAKE_Fortran_COMPILER @PREFIX@/bin/@TARGET@-gfortran)
|
||||||
|
set(CMAKE_RC_COMPILER @PREFIX@/bin/@TARGET@-windres)
|
||||||
|
# CMAKE_RC_COMPILE_OBJECT is defined in:
|
||||||
|
# <cmake root>/share/cmake-X.Y/Modules/Platform/Windows-windres.cmake
|
||||||
|
set(CPACK_NSIS_EXECUTABLE @TARGET@-makensis)
|
||||||
|
|
||||||
|
## Individual package configuration
|
||||||
|
file(GLOB mxe_cmake_files
|
||||||
|
"@CMAKE_TOOLCHAIN_DIR@/*.cmake"
|
||||||
|
)
|
||||||
|
foreach(mxe_cmake_file ${mxe_cmake_files})
|
||||||
|
include(${mxe_cmake_file})
|
||||||
|
endforeach()
|
29
contrib/depends/packages/cmake/conf/target-cmake.in
Normal file
29
contrib/depends/packages/cmake/conf/target-cmake.in
Normal file
@ -0,0 +1,29 @@
|
|||||||
|
#!/usr/bin/env bash
|
||||||
|
echo "== Using MXE wrapper: @PREFIX@/bin/@TARGET@-cmake"
|
||||||
|
|
||||||
|
# https://cmake.org/cmake/help/latest/manual/cmake-policies.7.html
|
||||||
|
# https://cmake.org/cmake/help/latest/variable/CMAKE_POLICY_DEFAULT_CMPNNNN.html
|
||||||
|
POLICIES=(0017,0020)
|
||||||
|
|
||||||
|
unset NO_MXE_TOOLCHAIN
|
||||||
|
if echo -- "$@" | grep -Ewq "(--build|-E|--system-information)" ; then
|
||||||
|
NO_MXE_TOOLCHAIN=1
|
||||||
|
fi
|
||||||
|
if [[ "$NO_MXE_TOOLCHAIN" == "1" ]]; then
|
||||||
|
echo "== Skip using MXE toolchain: @CMAKE_TOOLCHAIN_FILE@"
|
||||||
|
# see https://github.com/mxe/mxe/issues/932
|
||||||
|
exec "@PREFIX@/@BUILD@/bin/cmake" "$@"
|
||||||
|
else
|
||||||
|
echo " - cmake version @CMAKE_VERSION@"
|
||||||
|
echo " - warnings for unused CMAKE_POLICY_DEFAULT variables can be ignored"
|
||||||
|
echo "== Using MXE toolchain: @CMAKE_TOOLCHAIN_FILE@"
|
||||||
|
echo "== Using MXE runresult: @CMAKE_RUNRESULT_FILE@"
|
||||||
|
if ! ( echo "$@" | grep --silent "DCMAKE_BUILD_TYPE" ) ; then
|
||||||
|
echo '== Adding "-DCMAKE_BUILD_TYPE=Release"'
|
||||||
|
set -- "-DCMAKE_BUILD_TYPE=Release" "$@"
|
||||||
|
fi
|
||||||
|
exec "@PREFIX@/@BUILD@/bin/cmake" \
|
||||||
|
-DCMAKE_TOOLCHAIN_FILE="@CMAKE_TOOLCHAIN_FILE@" \
|
||||||
|
`eval echo -DCMAKE_POLICY_DEFAULT_CMP{$POLICIES}=NEW` \
|
||||||
|
-C"@CMAKE_RUNRESULT_FILE@" "$@"
|
||||||
|
fi
|
18
contrib/depends/packages/cmake/test/CMakeLists.txt
Normal file
18
contrib/depends/packages/cmake/test/CMakeLists.txt
Normal file
@ -0,0 +1,18 @@
|
|||||||
|
# This file is part of MXE. See LICENSE.md for licensing information.
|
||||||
|
|
||||||
|
# 2.8.9 is Debian Wheezy version
|
||||||
|
cmake_minimum_required(VERSION 2.8.9)
|
||||||
|
|
||||||
|
# use default C and CXX languages
|
||||||
|
project(mxe)
|
||||||
|
|
||||||
|
# see cmake --help-policy <cmp> for details
|
||||||
|
cmake_policy(SET CMP0017 NEW)
|
||||||
|
if (POLICY CMP0020)
|
||||||
|
cmake_policy(SET CMP0020 NEW)
|
||||||
|
endif()
|
||||||
|
|
||||||
|
# so we can find pkg-test.cmake files to include
|
||||||
|
set(CMAKE_MODULE_PATH ${CMAKE_CURRENT_LIST_DIR}/../.. ${CMAKE_MODULE_PATH})
|
||||||
|
|
||||||
|
include(${PKG}-test)
|
15
contrib/depends/packages/cppzmq.mk
Normal file
15
contrib/depends/packages/cppzmq.mk
Normal file
@ -0,0 +1,15 @@
|
|||||||
|
package=cppzmq
|
||||||
|
$(package)_version=4.2.3
|
||||||
|
$(package)_download_path=https://github.com/zeromq/cppzmq/archive/
|
||||||
|
$(package)_file_name=v$($(package)_version).tar.gz
|
||||||
|
$(package)_sha256_hash=3e6b57bf49115f4ae893b1ff7848ead7267013087dc7be1ab27636a97144d373
|
||||||
|
$(package)_dependencies=zeromq
|
||||||
|
|
||||||
|
define $(package)_stage_cmds
|
||||||
|
mkdir $($(package)_staging_prefix_dir)/include &&\
|
||||||
|
cp zmq.hpp $($(package)_staging_prefix_dir)/include
|
||||||
|
endef
|
||||||
|
|
||||||
|
define $(package)_postprocess_cmds
|
||||||
|
rm -rf bin share
|
||||||
|
endef
|
22
contrib/depends/packages/expat.mk
Normal file
22
contrib/depends/packages/expat.mk
Normal file
@ -0,0 +1,22 @@
|
|||||||
|
package=expat
|
||||||
|
$(package)_version=2.2.4
|
||||||
|
$(package)_download_path=https://downloads.sourceforge.net/project/expat/expat/$($(package)_version)
|
||||||
|
$(package)_file_name=$(package)-$($(package)_version).tar.bz2
|
||||||
|
$(package)_sha256_hash=03ad85db965f8ab2d27328abcf0bc5571af6ec0a414874b2066ee3fdd372019e
|
||||||
|
|
||||||
|
define $(package)_set_vars
|
||||||
|
$(package)_config_opts=--enable-static
|
||||||
|
$(package)_config_opts+=--prefix=$(host_prefix)
|
||||||
|
endef
|
||||||
|
|
||||||
|
define $(package)_config_cmds
|
||||||
|
$($(package)_autoconf) $($(package)_config_opts)
|
||||||
|
endef
|
||||||
|
|
||||||
|
define $(package)_build_cmds
|
||||||
|
$(MAKE)
|
||||||
|
endef
|
||||||
|
|
||||||
|
define $(package)_stage_cmds
|
||||||
|
$(MAKE) DESTDIR=$($(package)_staging_dir) install
|
||||||
|
endef
|
30
contrib/depends/packages/graphviz.mk
Normal file
30
contrib/depends/packages/graphviz.mk
Normal file
@ -0,0 +1,30 @@
|
|||||||
|
package=graphviz
|
||||||
|
$(package)_version=2.40.1
|
||||||
|
$(package)_download_path=www.graphviz.org/pub/graphviz/stable/SOURCES/
|
||||||
|
$(package)_file_name=$(package)-$($(package)_version).tar.gz
|
||||||
|
$(package)_sha256_hash=ca5218fade0204d59947126c38439f432853543b0818d9d728c589dfe7f3a421
|
||||||
|
|
||||||
|
define $(package)_preprocess_cmds
|
||||||
|
./autogen.sh
|
||||||
|
endef
|
||||||
|
|
||||||
|
define $(package)_set_vars
|
||||||
|
$(package)_config_opts=--disable-shared --enable-multibye --without-purify --without-curses
|
||||||
|
$(package)_config_opts_release=--disable-debug-mode
|
||||||
|
$(package)_config_opts_linux=--with-pic
|
||||||
|
endef
|
||||||
|
|
||||||
|
define $(package)_config_cmds
|
||||||
|
$($(package)_autoconf)
|
||||||
|
endef
|
||||||
|
|
||||||
|
define $(package)_build_cmds
|
||||||
|
$(MAKE)
|
||||||
|
endef
|
||||||
|
|
||||||
|
define $(package)_stage_cmds
|
||||||
|
$(MAKE) DESTDIR=$($(package)_staging_dir) install
|
||||||
|
endef
|
||||||
|
|
||||||
|
define $(package)_postprocess_cmds
|
||||||
|
endef
|
32
contrib/depends/packages/icu4c.mk
Normal file
32
contrib/depends/packages/icu4c.mk
Normal file
@ -0,0 +1,32 @@
|
|||||||
|
package=icu4c
|
||||||
|
$(package)_version=55.1
|
||||||
|
$(package)_download_path=https://github.com/TheCharlatan/icu4c/archive
|
||||||
|
$(package)_file_name=55.1.tar.gz
|
||||||
|
$(package)_sha256_hash=1f912c54035533fb4268809701d65c7468d00e292efbc31e6444908450cc46ef
|
||||||
|
$(package)_patches=icu-001-dont-build-static-dynamic-twice.patch
|
||||||
|
|
||||||
|
define $(package)_set_vars
|
||||||
|
$(package)_build_opts=CFLAGS="$($(package)_cflags) $($(package)_cppflags) -DU_USING_ICU_NAMESPACE=0 --std=gnu++0x -DU_STATIC_IMPLEMENTATION -DU_COMBINED_IMPLEMENTATION -fPIC"
|
||||||
|
endef
|
||||||
|
|
||||||
|
define $(package)_config_cmds
|
||||||
|
patch -p1 < $($(package)_patch_dir)/icu-001-dont-build-static-dynamic-twice.patch &&\
|
||||||
|
mkdir builda &&\
|
||||||
|
mkdir buildb &&\
|
||||||
|
cd builda &&\
|
||||||
|
sh ../source/runConfigureICU Linux &&\
|
||||||
|
make &&\
|
||||||
|
cd ../buildb &&\
|
||||||
|
sh ../source/$($(package)_autoconf) --enable-static=yes --enable-shared=yes --disable-layoutex --prefix=$(host_prefix) --with-cross-build=`pwd`/../builda &&\
|
||||||
|
$(MAKE) $($(package)_build_opts)
|
||||||
|
endef
|
||||||
|
|
||||||
|
#define $(package)_build_cmds
|
||||||
|
# cd source &&\
|
||||||
|
$(MAKE) $($((package)_build_opts) `nproc`
|
||||||
|
#endef
|
||||||
|
|
||||||
|
define $(package)_stage_cmds
|
||||||
|
cd buildb &&\
|
||||||
|
$(MAKE) $($(package)_build_opts) DESTDIR=$($(package)_staging_dir) install lib/*
|
||||||
|
endef
|
28
contrib/depends/packages/ldns.mk
Normal file
28
contrib/depends/packages/ldns.mk
Normal file
@ -0,0 +1,28 @@
|
|||||||
|
package=ldns
|
||||||
|
$(package)_version=1.6.17
|
||||||
|
$(package)_download_path=http://www.nlnetlabs.nl/downloads/ldns/
|
||||||
|
$(package)_file_name=$(package)-$($(package)_version).tar.gz
|
||||||
|
$(package)_sha256_hash=8b88e059452118e8949a2752a55ce59bc71fa5bc414103e17f5b6b06f9bcc8cd
|
||||||
|
$(package)_dependencies=openssl
|
||||||
|
|
||||||
|
define $(package)_set_vars
|
||||||
|
$(package)_config_opts=--disable-shared --enable-static --disable-dane-ta-usage --with-drill
|
||||||
|
$(package)_config_opts=--with-ssl=$(host_prefix)
|
||||||
|
$(package)_config_opts_release=--disable-debug-mode
|
||||||
|
$(package)_config_opts_linux=--with-pic
|
||||||
|
endef
|
||||||
|
|
||||||
|
define $(package)_config_cmds
|
||||||
|
$($(package)_autoconf)
|
||||||
|
endef
|
||||||
|
|
||||||
|
define $(package)_build_cmds
|
||||||
|
$(MAKE)
|
||||||
|
endef
|
||||||
|
|
||||||
|
define $(package)_stage_cmds
|
||||||
|
$(MAKE) DESTDIR=$($(package)_staging_dir) install-h install-lib
|
||||||
|
endef
|
||||||
|
|
||||||
|
define $(package)_postprocess_cmds
|
||||||
|
endef
|
23
contrib/depends/packages/libICE.mk
Normal file
23
contrib/depends/packages/libICE.mk
Normal file
@ -0,0 +1,23 @@
|
|||||||
|
package=libICE
|
||||||
|
$(package)_version=1.0.9
|
||||||
|
$(package)_download_path=http://xorg.freedesktop.org/releases/individual/lib/
|
||||||
|
$(package)_file_name=$(package)-$($(package)_version).tar.bz2
|
||||||
|
$(package)_sha256_hash=8f7032f2c1c64352b5423f6b48a8ebdc339cc63064af34d66a6c9aa79759e202
|
||||||
|
$(package)_dependencies=xtrans xproto
|
||||||
|
|
||||||
|
define $(package)_set_vars
|
||||||
|
$(package)_config_opts=--disable-static --disable-docs --disable-specs --without-xsltproc
|
||||||
|
$(package)_config_opts_linux=--with-pic
|
||||||
|
endef
|
||||||
|
|
||||||
|
define $(package)_config_cmds
|
||||||
|
$($(package)_autoconf)
|
||||||
|
endef
|
||||||
|
|
||||||
|
define $(package)_build_cmds
|
||||||
|
$(MAKE)
|
||||||
|
endef
|
||||||
|
|
||||||
|
define $(package)_stage_cmds
|
||||||
|
$(MAKE) DESTDIR=$($(package)_staging_dir) install
|
||||||
|
endef
|
23
contrib/depends/packages/libSM.mk
Normal file
23
contrib/depends/packages/libSM.mk
Normal file
@ -0,0 +1,23 @@
|
|||||||
|
package=libSM
|
||||||
|
$(package)_version=1.2.2
|
||||||
|
$(package)_download_path=http://xorg.freedesktop.org/releases/individual/lib/
|
||||||
|
$(package)_file_name=$(package)-$($(package)_version).tar.bz2
|
||||||
|
$(package)_sha256_hash=0baca8c9f5d934450a70896c4ad38d06475521255ca63b717a6510fdb6e287bd
|
||||||
|
$(package)_dependencies=xtrans xproto libICE
|
||||||
|
|
||||||
|
define $(package)_set_vars
|
||||||
|
$(package)_config_opts=--without-libuuid --without-xsltproc --disable-docs --disable-static
|
||||||
|
$(package)_config_opts_linux=--with-pic
|
||||||
|
endef
|
||||||
|
|
||||||
|
define $(package)_config_cmds
|
||||||
|
$($(package)_autoconf)
|
||||||
|
endef
|
||||||
|
|
||||||
|
define $(package)_build_cmds
|
||||||
|
$(MAKE)
|
||||||
|
endef
|
||||||
|
|
||||||
|
define $(package)_stage_cmds
|
||||||
|
$(MAKE) DESTDIR=$($(package)_staging_dir) install
|
||||||
|
endef
|
30
contrib/depends/packages/libevent.mk
Normal file
30
contrib/depends/packages/libevent.mk
Normal file
@ -0,0 +1,30 @@
|
|||||||
|
package=libevent
|
||||||
|
$(package)_version=2.1.8-stable
|
||||||
|
$(package)_download_path=https://github.com/libevent/libevent/archive/
|
||||||
|
$(package)_file_name=release-$($(package)_version).tar.gz
|
||||||
|
$(package)_sha256_hash=316ddb401745ac5d222d7c529ef1eada12f58f6376a66c1118eee803cb70f83d
|
||||||
|
|
||||||
|
define $(package)_preprocess_cmds
|
||||||
|
./autogen.sh
|
||||||
|
endef
|
||||||
|
|
||||||
|
define $(package)_set_vars
|
||||||
|
$(package)_config_opts=--disable-shared --disable-openssl --disable-libevent-regress --disable-samples
|
||||||
|
$(package)_config_opts_release=--disable-debug-mode
|
||||||
|
$(package)_config_opts_linux=--with-pic
|
||||||
|
endef
|
||||||
|
|
||||||
|
define $(package)_config_cmds
|
||||||
|
$($(package)_autoconf)
|
||||||
|
endef
|
||||||
|
|
||||||
|
define $(package)_build_cmds
|
||||||
|
$(MAKE)
|
||||||
|
endef
|
||||||
|
|
||||||
|
define $(package)_stage_cmds
|
||||||
|
$(MAKE) DESTDIR=$($(package)_staging_dir) install
|
||||||
|
endef
|
||||||
|
|
||||||
|
define $(package)_postprocess_cmds
|
||||||
|
endef
|
17
contrib/depends/packages/libiconv.mk
Normal file
17
contrib/depends/packages/libiconv.mk
Normal file
@ -0,0 +1,17 @@
|
|||||||
|
package=libiconv
|
||||||
|
$(package)_version=1.15
|
||||||
|
$(package)_download_path=https://ftp.gnu.org/gnu/libiconv
|
||||||
|
$(package)_file_name=libiconv-$($(package)_version).tar.gz
|
||||||
|
$(package)_sha256_hash=ccf536620a45458d26ba83887a983b96827001e92a13847b45e4925cc8913178
|
||||||
|
|
||||||
|
define $(package)_config_cmds
|
||||||
|
$($(package)_autoconf) --disable-nls --enable-static --disable-shared
|
||||||
|
endef
|
||||||
|
|
||||||
|
define $(package)_build_cmds
|
||||||
|
$(MAKE)
|
||||||
|
endef
|
||||||
|
|
||||||
|
define $(package)_stage_cmds
|
||||||
|
$(MAKE) DESTDIR=$($(package)_staging_dir) install
|
||||||
|
endef
|
28
contrib/depends/packages/miniupnpc.mk
Normal file
28
contrib/depends/packages/miniupnpc.mk
Normal file
@ -0,0 +1,28 @@
|
|||||||
|
package=miniupnpc
|
||||||
|
$(package)_version=2.0.20170509
|
||||||
|
$(package)_download_path=http://miniupnp.free.fr/files
|
||||||
|
$(package)_file_name=$(package)-$($(package)_version).tar.gz
|
||||||
|
$(package)_sha256_hash=d3c368627f5cdfb66d3ebd64ca39ba54d6ff14a61966dbecb8dd296b7039f16a
|
||||||
|
|
||||||
|
define $(package)_set_vars
|
||||||
|
$(package)_build_opts=CC="$($(package)_cc)"
|
||||||
|
$(package)_build_opts_darwin=OS=Darwin LIBTOOL="$($(package)_libtool)"
|
||||||
|
$(package)_build_opts_mingw32=-f Makefile.mingw
|
||||||
|
$(package)_build_env+=CFLAGS="$($(package)_cflags) $($(package)_cppflags)" AR="$($(package)_ar)"
|
||||||
|
endef
|
||||||
|
|
||||||
|
define $(package)_preprocess_cmds
|
||||||
|
mkdir dll && \
|
||||||
|
sed -e 's|MINIUPNPC_VERSION_STRING \"version\"|MINIUPNPC_VERSION_STRING \"$($(package)_version)\"|' -e 's|OS/version|$(host)|' miniupnpcstrings.h.in > miniupnpcstrings.h && \
|
||||||
|
sed -i.old "s|miniupnpcstrings.h: miniupnpcstrings.h.in wingenminiupnpcstrings|miniupnpcstrings.h: miniupnpcstrings.h.in|" Makefile.mingw
|
||||||
|
endef
|
||||||
|
|
||||||
|
define $(package)_build_cmds
|
||||||
|
$(MAKE) libminiupnpc.a $($(package)_build_opts)
|
||||||
|
endef
|
||||||
|
|
||||||
|
define $(package)_stage_cmds
|
||||||
|
mkdir -p $($(package)_staging_prefix_dir)/include/miniupnpc $($(package)_staging_prefix_dir)/lib &&\
|
||||||
|
install *.h $($(package)_staging_prefix_dir)/include/miniupnpc &&\
|
||||||
|
install libminiupnpc.a $($(package)_staging_prefix_dir)/lib
|
||||||
|
endef
|
20
contrib/depends/packages/native_biplist.mk
Normal file
20
contrib/depends/packages/native_biplist.mk
Normal file
@ -0,0 +1,20 @@
|
|||||||
|
package=native_biplist
|
||||||
|
$(package)_version=0.9
|
||||||
|
$(package)_download_path=https://pypi.python.org/packages/source/b/biplist
|
||||||
|
$(package)_file_name=biplist-$($(package)_version).tar.gz
|
||||||
|
$(package)_sha256_hash=b57cadfd26e4754efdf89e9e37de87885f9b5c847b2615688ca04adfaf6ca604
|
||||||
|
$(package)_install_libdir=$(build_prefix)/lib/python/dist-packages
|
||||||
|
$(package)_patches=sorted_list.patch
|
||||||
|
|
||||||
|
define $(package)_preprocess_cmds
|
||||||
|
patch -p1 < $($(package)_patch_dir)/sorted_list.patch
|
||||||
|
endef
|
||||||
|
|
||||||
|
define $(package)_build_cmds
|
||||||
|
python setup.py build
|
||||||
|
endef
|
||||||
|
|
||||||
|
define $(package)_stage_cmds
|
||||||
|
mkdir -p $($(package)_install_libdir) && \
|
||||||
|
python setup.py install --root=$($(package)_staging_dir) --prefix=$(build_prefix) --install-lib=$($(package)_install_libdir)
|
||||||
|
endef
|
25
contrib/depends/packages/native_ccache.mk
Normal file
25
contrib/depends/packages/native_ccache.mk
Normal file
@ -0,0 +1,25 @@
|
|||||||
|
package=native_ccache
|
||||||
|
$(package)_version=3.3.4
|
||||||
|
$(package)_download_path=https://samba.org/ftp/ccache
|
||||||
|
$(package)_file_name=ccache-$($(package)_version).tar.bz2
|
||||||
|
$(package)_sha256_hash=fa9d7f38367431bc86b19ad107d709ca7ecf1574fdacca01698bdf0a47cd8567
|
||||||
|
|
||||||
|
define $(package)_set_vars
|
||||||
|
$(package)_config_opts=
|
||||||
|
endef
|
||||||
|
|
||||||
|
define $(package)_config_cmds
|
||||||
|
$($(package)_autoconf)
|
||||||
|
endef
|
||||||
|
|
||||||
|
define $(package)_build_cmds
|
||||||
|
$(MAKE)
|
||||||
|
endef
|
||||||
|
|
||||||
|
define $(package)_stage_cmds
|
||||||
|
$(MAKE) DESTDIR=$($(package)_staging_dir) install
|
||||||
|
endef
|
||||||
|
|
||||||
|
define $(package)_postprocess_cmds
|
||||||
|
rm -rf lib include
|
||||||
|
endef
|
65
contrib/depends/packages/native_cctools.mk
Normal file
65
contrib/depends/packages/native_cctools.mk
Normal file
@ -0,0 +1,65 @@
|
|||||||
|
package=native_cctools
|
||||||
|
$(package)_version=807d6fd1be5d2224872e381870c0a75387fe05e6
|
||||||
|
$(package)_download_path=https://github.com/theuni/cctools-port/archive
|
||||||
|
$(package)_file_name=$($(package)_version).tar.gz
|
||||||
|
$(package)_sha256_hash=a09c9ba4684670a0375e42d9d67e7f12c1f62581a27f28f7c825d6d7032ccc6a
|
||||||
|
$(package)_build_subdir=cctools
|
||||||
|
$(package)_clang_version=3.7.1
|
||||||
|
$(package)_clang_download_path=http://llvm.org/releases/$($(package)_clang_version)
|
||||||
|
$(package)_clang_download_file=clang+llvm-$($(package)_clang_version)-x86_64-linux-gnu-ubuntu-14.04.tar.xz
|
||||||
|
$(package)_clang_file_name=clang-llvm-$($(package)_clang_version)-x86_64-linux-gnu-ubuntu-14.04.tar.xz
|
||||||
|
$(package)_clang_sha256_hash=99b28a6b48e793705228a390471991386daa33a9717cd9ca007fcdde69608fd9
|
||||||
|
$(package)_extra_sources=$($(package)_clang_file_name)
|
||||||
|
|
||||||
|
define $(package)_fetch_cmds
|
||||||
|
$(call fetch_file,$(package),$($(package)_download_path),$($(package)_download_file),$($(package)_file_name),$($(package)_sha256_hash)) && \
|
||||||
|
$(call fetch_file,$(package),$($(package)_clang_download_path),$($(package)_clang_download_file),$($(package)_clang_file_name),$($(package)_clang_sha256_hash))
|
||||||
|
endef
|
||||||
|
|
||||||
|
define $(package)_extract_cmds
|
||||||
|
mkdir -p $($(package)_extract_dir) && \
|
||||||
|
echo "$($(package)_sha256_hash) $($(package)_source)" > $($(package)_extract_dir)/.$($(package)_file_name).hash && \
|
||||||
|
echo "$($(package)_clang_sha256_hash) $($(package)_source_dir)/$($(package)_clang_file_name)" >> $($(package)_extract_dir)/.$($(package)_file_name).hash && \
|
||||||
|
$(build_SHA256SUM) -c $($(package)_extract_dir)/.$($(package)_file_name).hash && \
|
||||||
|
mkdir -p toolchain/bin toolchain/lib/clang/3.5/include && \
|
||||||
|
tar --strip-components=1 -C toolchain -xf $($(package)_source_dir)/$($(package)_clang_file_name) && \
|
||||||
|
rm -f toolchain/lib/libc++abi.so* && \
|
||||||
|
echo "#!/bin/sh" > toolchain/bin/$(host)-dsymutil && \
|
||||||
|
echo "exit 0" >> toolchain/bin/$(host)-dsymutil && \
|
||||||
|
chmod +x toolchain/bin/$(host)-dsymutil && \
|
||||||
|
tar --strip-components=1 -xf $($(package)_source)
|
||||||
|
endef
|
||||||
|
|
||||||
|
define $(package)_set_vars
|
||||||
|
$(package)_config_opts=--target=$(host) --disable-lto-support
|
||||||
|
$(package)_ldflags+=-Wl,-rpath=\\$$$$$$$$\$$$$$$$$ORIGIN/../lib
|
||||||
|
$(package)_cc=$($(package)_extract_dir)/toolchain/bin/clang
|
||||||
|
$(package)_cxx=$($(package)_extract_dir)/toolchain/bin/clang++
|
||||||
|
endef
|
||||||
|
|
||||||
|
define $(package)_preprocess_cmds
|
||||||
|
cd $($(package)_build_subdir); ./autogen.sh && \
|
||||||
|
sed -i.old "/define HAVE_PTHREADS/d" ld64/src/ld/InputFiles.h
|
||||||
|
endef
|
||||||
|
|
||||||
|
define $(package)_config_cmds
|
||||||
|
$($(package)_autoconf)
|
||||||
|
endef
|
||||||
|
|
||||||
|
define $(package)_build_cmds
|
||||||
|
$(MAKE)
|
||||||
|
endef
|
||||||
|
|
||||||
|
define $(package)_stage_cmds
|
||||||
|
$(MAKE) DESTDIR=$($(package)_staging_dir) install && \
|
||||||
|
cd $($(package)_extract_dir)/toolchain && \
|
||||||
|
mkdir -p $($(package)_staging_prefix_dir)/lib/clang/$($(package)_clang_version)/include && \
|
||||||
|
mkdir -p $($(package)_staging_prefix_dir)/bin $($(package)_staging_prefix_dir)/include && \
|
||||||
|
cp bin/clang $($(package)_staging_prefix_dir)/bin/ &&\
|
||||||
|
cp -P bin/clang++ $($(package)_staging_prefix_dir)/bin/ &&\
|
||||||
|
cp lib/libLTO.so $($(package)_staging_prefix_dir)/lib/ && \
|
||||||
|
cp -rf lib/clang/$($(package)_clang_version)/include/* $($(package)_staging_prefix_dir)/lib/clang/$($(package)_clang_version)/include/ && \
|
||||||
|
cp bin/llvm-dsymutil $($(package)_staging_prefix_dir)/bin/$(host)-dsymutil && \
|
||||||
|
if `test -d include/c++/`; then cp -rf include/c++/ $($(package)_staging_prefix_dir)/include/; fi && \
|
||||||
|
if `test -d lib/c++/`; then cp -rf lib/c++/ $($(package)_staging_prefix_dir)/lib/; fi
|
||||||
|
endef
|
26
contrib/depends/packages/native_cdrkit.mk
Normal file
26
contrib/depends/packages/native_cdrkit.mk
Normal file
@ -0,0 +1,26 @@
|
|||||||
|
package=native_cdrkit
|
||||||
|
$(package)_version=1.1.11
|
||||||
|
$(package)_download_path=http://distro.ibiblio.org/fatdog/source/600/c
|
||||||
|
$(package)_file_name=cdrkit-$($(package)_version).tar.bz2
|
||||||
|
$(package)_sha256_hash=b50d64c214a65b1a79afe3a964c691931a4233e2ba605d793eb85d0ac3652564
|
||||||
|
$(package)_patches=cdrkit-deterministic.patch
|
||||||
|
|
||||||
|
define $(package)_preprocess_cmds
|
||||||
|
patch -p1 < $($(package)_patch_dir)/cdrkit-deterministic.patch
|
||||||
|
endef
|
||||||
|
|
||||||
|
define $(package)_config_cmds
|
||||||
|
cmake -DCMAKE_INSTALL_PREFIX=$(build_prefix)
|
||||||
|
endef
|
||||||
|
|
||||||
|
define $(package)_build_cmds
|
||||||
|
$(MAKE) genisoimage
|
||||||
|
endef
|
||||||
|
|
||||||
|
define $(package)_stage_cmds
|
||||||
|
$(MAKE) DESTDIR=$($(package)_staging_dir) -C genisoimage install
|
||||||
|
endef
|
||||||
|
|
||||||
|
define $(package)_postprocess_cmds
|
||||||
|
rm bin/isovfy bin/isoinfo bin/isodump bin/isodebug bin/devdump
|
||||||
|
endef
|
17
contrib/depends/packages/native_ds_store.mk
Normal file
17
contrib/depends/packages/native_ds_store.mk
Normal file
@ -0,0 +1,17 @@
|
|||||||
|
package=native_ds_store
|
||||||
|
$(package)_version=1.1.0
|
||||||
|
$(package)_download_path=https://bitbucket.org/al45tair/ds_store/get
|
||||||
|
$(package)_download_file=v$($(package)_version).tar.bz2
|
||||||
|
$(package)_file_name=$(package)-$($(package)_version).tar.bz2
|
||||||
|
$(package)_sha256_hash=921596764d71d1bbd3297a90ef6d286f718794d667e4f81d91d14053525d64c1
|
||||||
|
$(package)_install_libdir=$(build_prefix)/lib/python/dist-packages
|
||||||
|
$(package)_dependencies=native_biplist
|
||||||
|
|
||||||
|
define $(package)_build_cmds
|
||||||
|
python setup.py build
|
||||||
|
endef
|
||||||
|
|
||||||
|
define $(package)_stage_cmds
|
||||||
|
mkdir -p $($(package)_install_libdir) && \
|
||||||
|
python setup.py install --root=$($(package)_staging_dir) --prefix=$(build_prefix) --install-lib=$($(package)_install_libdir)
|
||||||
|
endef
|
22
contrib/depends/packages/native_libdmg-hfsplus.mk
Normal file
22
contrib/depends/packages/native_libdmg-hfsplus.mk
Normal file
@ -0,0 +1,22 @@
|
|||||||
|
package=native_libdmg-hfsplus
|
||||||
|
$(package)_version=0.1
|
||||||
|
$(package)_download_path=https://github.com/theuni/libdmg-hfsplus/archive
|
||||||
|
$(package)_file_name=libdmg-hfsplus-v$($(package)_version).tar.gz
|
||||||
|
$(package)_sha256_hash=6569a02eb31c2827080d7d59001869ea14484c281efab0ae7f2b86af5c3120b3
|
||||||
|
$(package)_build_subdir=build
|
||||||
|
|
||||||
|
define $(package)_preprocess_cmds
|
||||||
|
mkdir build
|
||||||
|
endef
|
||||||
|
|
||||||
|
define $(package)_config_cmds
|
||||||
|
cmake -DCMAKE_INSTALL_PREFIX:PATH=$(build_prefix)/bin ..
|
||||||
|
endef
|
||||||
|
|
||||||
|
define $(package)_build_cmds
|
||||||
|
$(MAKE) -C dmg
|
||||||
|
endef
|
||||||
|
|
||||||
|
define $(package)_stage_cmds
|
||||||
|
$(MAKE) DESTDIR=$($(package)_staging_dir) -C dmg install
|
||||||
|
endef
|
21
contrib/depends/packages/native_mac_alias.mk
Normal file
21
contrib/depends/packages/native_mac_alias.mk
Normal file
@ -0,0 +1,21 @@
|
|||||||
|
package=native_mac_alias
|
||||||
|
$(package)_version=1.1.0
|
||||||
|
$(package)_download_path=https://bitbucket.org/al45tair/mac_alias/get
|
||||||
|
$(package)_download_file=v$($(package)_version).tar.bz2
|
||||||
|
$(package)_file_name=$(package)-$($(package)_version).tar.bz2
|
||||||
|
$(package)_sha256_hash=87ad827e66790028361e43fc754f68ed041a9bdb214cca03c853f079b04fb120
|
||||||
|
$(package)_install_libdir=$(build_prefix)/lib/python/dist-packages
|
||||||
|
$(package)_patches=python3.patch
|
||||||
|
|
||||||
|
define $(package)_preprocess_cmds
|
||||||
|
patch -p1 < $($(package)_patch_dir)/python3.patch
|
||||||
|
endef
|
||||||
|
|
||||||
|
define $(package)_build_cmds
|
||||||
|
python setup.py build
|
||||||
|
endef
|
||||||
|
|
||||||
|
define $(package)_stage_cmds
|
||||||
|
mkdir -p $($(package)_install_libdir) && \
|
||||||
|
python setup.py install --root=$($(package)_staging_dir) --prefix=$(build_prefix) --install-lib=$($(package)_install_libdir)
|
||||||
|
endef
|
78
contrib/depends/packages/openssl.mk
Normal file
78
contrib/depends/packages/openssl.mk
Normal file
@ -0,0 +1,78 @@
|
|||||||
|
package=openssl
|
||||||
|
$(package)_version=1.0.1k
|
||||||
|
$(package)_download_path=https://www.openssl.org/source
|
||||||
|
$(package)_file_name=$(package)-$($(package)_version).tar.gz
|
||||||
|
$(package)_sha256_hash=8f9faeaebad088e772f4ef5e38252d472be4d878c6b3a2718c10a4fcebe7a41c
|
||||||
|
|
||||||
|
define $(package)_set_vars
|
||||||
|
$(package)_config_env=AR="$($(package)_ar)" RANLIB="$($(package)_ranlib)" CC="$($(package)_cc)"
|
||||||
|
$(package)_config_opts=--prefix=$(host_prefix) --openssldir=$(host_prefix)/etc/openssl
|
||||||
|
$(package)_config_opts+=no-camellia
|
||||||
|
$(package)_config_opts+=no-capieng
|
||||||
|
$(package)_config_opts+=no-cast
|
||||||
|
$(package)_config_opts+=no-comp
|
||||||
|
$(package)_config_opts+=no-dso
|
||||||
|
$(package)_config_opts+=no-dtls1
|
||||||
|
$(package)_config_opts+=no-ec_nistp_64_gcc_128
|
||||||
|
$(package)_config_opts+=no-gost
|
||||||
|
$(package)_config_opts+=no-gmp
|
||||||
|
$(package)_config_opts+=no-heartbeats
|
||||||
|
$(package)_config_opts+=no-idea
|
||||||
|
$(package)_config_opts+=no-jpake
|
||||||
|
$(package)_config_opts+=no-krb5
|
||||||
|
$(package)_config_opts+=no-libunbound
|
||||||
|
$(package)_config_opts+=no-md2
|
||||||
|
$(package)_config_opts+=no-mdc2
|
||||||
|
$(package)_config_opts+=no-rc4
|
||||||
|
$(package)_config_opts+=no-rc5
|
||||||
|
$(package)_config_opts+=no-rdrand
|
||||||
|
$(package)_config_opts+=no-rfc3779
|
||||||
|
$(package)_config_opts+=no-rsax
|
||||||
|
$(package)_config_opts+=no-sctp
|
||||||
|
$(package)_config_opts+=no-seed
|
||||||
|
$(package)_config_opts+=no-sha0
|
||||||
|
$(package)_config_opts+=no-shared
|
||||||
|
$(package)_config_opts+=no-ssl-trace
|
||||||
|
$(package)_config_opts+=no-ssl2
|
||||||
|
$(package)_config_opts+=no-ssl3
|
||||||
|
$(package)_config_opts+=no-static_engine
|
||||||
|
$(package)_config_opts+=no-store
|
||||||
|
$(package)_config_opts+=no-unit-test
|
||||||
|
$(package)_config_opts+=no-weak-ssl-ciphers
|
||||||
|
$(package)_config_opts+=no-whirlpool
|
||||||
|
$(package)_config_opts+=no-zlib
|
||||||
|
$(package)_config_opts+=no-zlib-dynamic
|
||||||
|
$(package)_config_opts+=$($(package)_cflags) $($(package)_cppflags)
|
||||||
|
$(package)_config_opts_linux=-fPIC -Wa,--noexecstack
|
||||||
|
$(package)_config_opts_x86_64_linux=linux-x86_64
|
||||||
|
$(package)_config_opts_i686_linux=linux-generic32
|
||||||
|
$(package)_config_opts_arm_linux=linux-generic32
|
||||||
|
$(package)_config_opts_aarch64_linux=linux-generic64
|
||||||
|
$(package)_config_opts_mipsel_linux=linux-generic32
|
||||||
|
$(package)_config_opts_mips_linux=linux-generic32
|
||||||
|
$(package)_config_opts_powerpc_linux=linux-generic32
|
||||||
|
$(package)_config_opts_x86_64_darwin=darwin64-x86_64-cc
|
||||||
|
$(package)_config_opts_x86_64_mingw32=mingw64
|
||||||
|
$(package)_config_opts_i686_mingw32=mingw
|
||||||
|
endef
|
||||||
|
|
||||||
|
define $(package)_preprocess_cmds
|
||||||
|
sed -i.old "/define DATE/d" util/mkbuildinf.pl && \
|
||||||
|
sed -i.old "s|engines apps test|engines|" Makefile.org
|
||||||
|
endef
|
||||||
|
|
||||||
|
define $(package)_config_cmds
|
||||||
|
./Configure $($(package)_config_opts)
|
||||||
|
endef
|
||||||
|
|
||||||
|
define $(package)_build_cmds
|
||||||
|
$(MAKE) -j1 build_libs libcrypto.pc libssl.pc openssl.pc
|
||||||
|
endef
|
||||||
|
|
||||||
|
define $(package)_stage_cmds
|
||||||
|
$(MAKE) INSTALL_PREFIX=$($(package)_staging_dir) -j1 install_sw
|
||||||
|
endef
|
||||||
|
|
||||||
|
define $(package)_postprocess_cmds
|
||||||
|
rm -rf share bin etc
|
||||||
|
endef
|
21
contrib/depends/packages/packages.mk
Normal file
21
contrib/depends/packages/packages.mk
Normal file
@ -0,0 +1,21 @@
|
|||||||
|
packages:=boost openssl libevent zeromq cppzmq zlib expat ldns cppzmq readline libiconv qt sodium
|
||||||
|
native_packages := native_ccache
|
||||||
|
|
||||||
|
wallet_packages=bdb
|
||||||
|
|
||||||
|
darwin_native_packages = native_biplist native_ds_store native_mac_alias
|
||||||
|
|
||||||
|
ifeq ($(host_os),linux)
|
||||||
|
packages += pcsc-lite
|
||||||
|
packages += unwind
|
||||||
|
endif
|
||||||
|
ifeq ($(host_os),mingw32)
|
||||||
|
packages += icu4c
|
||||||
|
endif
|
||||||
|
|
||||||
|
ifneq ($(build_os),darwin)
|
||||||
|
darwin_native_packages += native_cctools native_cdrkit native_libdmg-hfsplus
|
||||||
|
packages += readline
|
||||||
|
endif
|
||||||
|
|
||||||
|
|
26
contrib/depends/packages/pcsc-lite.mk
Normal file
26
contrib/depends/packages/pcsc-lite.mk
Normal file
@ -0,0 +1,26 @@
|
|||||||
|
package=pcsc-lite
|
||||||
|
$(package)_version=1.8.23
|
||||||
|
$(package)_download_path=https://pcsclite.apdu.fr/files
|
||||||
|
$(package)_file_name=$(package)-$($(package)_version).tar.bz2
|
||||||
|
$(package)_sha256_hash=5a27262586eff39cfd5c19aadc8891dd71c0818d3d629539bd631b958be689c9
|
||||||
|
|
||||||
|
define $(package)_set_vars
|
||||||
|
$(package)_build_opts=CC="$($(package)_cc)"
|
||||||
|
$(package)_config_env=AR="$($(package)_ar)" RANLIB="$($(package)_ranlib)" CC="$($(package)_cc)"
|
||||||
|
$(package)_config_opts=--prefix=$(host_prefix)
|
||||||
|
$(package)_config_opts_release=--disable-debug-mode --disable-libsystemd --disable-libudev --enable-static --disable-shared --disable-libusb
|
||||||
|
$(package)_build_opts=CFLAGS="$($(package)_cflags) $($(package)_cppflags) -fPIC"
|
||||||
|
endef
|
||||||
|
|
||||||
|
define $(package)_config_cmds
|
||||||
|
./bootstrap &&\
|
||||||
|
$($(package)_autoconf) $($(package)_config_opts)
|
||||||
|
endef
|
||||||
|
|
||||||
|
define $(package)_build_cmds
|
||||||
|
$(MAKE) $($(package)_build_opts)
|
||||||
|
endef
|
||||||
|
|
||||||
|
define $(package)_stage_cmds
|
||||||
|
$(MAKE) DESTDIR=$($(package)_staging_dir) install
|
||||||
|
endef
|
29
contrib/depends/packages/protobuf.mk
Normal file
29
contrib/depends/packages/protobuf.mk
Normal file
@ -0,0 +1,29 @@
|
|||||||
|
package=protobuf
|
||||||
|
$(package)_version=$(native_$(package)_version)
|
||||||
|
$(package)_download_path=$(native_$(package)_download_path)
|
||||||
|
$(package)_file_name=$(native_$(package)_file_name)
|
||||||
|
$(package)_sha256_hash=$(native_$(package)_sha256_hash)
|
||||||
|
$(package)_dependencies=native_$(package)
|
||||||
|
$(package)_cxxflags=-std=c++11
|
||||||
|
|
||||||
|
define $(package)_set_vars
|
||||||
|
$(package)_config_opts=--disable-shared --with-protoc=$(build_prefix)/bin/protoc
|
||||||
|
$(package)_config_opts_linux=--with-pic
|
||||||
|
endef
|
||||||
|
|
||||||
|
define $(package)_config_cmds
|
||||||
|
$($(package)_autoconf)
|
||||||
|
endef
|
||||||
|
|
||||||
|
define $(package)_build_cmds
|
||||||
|
$(MAKE) -C src libprotobuf.la
|
||||||
|
endef
|
||||||
|
|
||||||
|
define $(package)_stage_cmds
|
||||||
|
$(MAKE) DESTDIR=$($(package)_staging_dir) -C src install-libLTLIBRARIES install-nobase_includeHEADERS &&\
|
||||||
|
$(MAKE) DESTDIR=$($(package)_staging_dir) install-pkgconfigDATA
|
||||||
|
endef
|
||||||
|
|
||||||
|
define $(package)_postprocess_cmds
|
||||||
|
rm lib/libprotoc.a
|
||||||
|
endef
|
150
contrib/depends/packages/qt.mk
Normal file
150
contrib/depends/packages/qt.mk
Normal file
@ -0,0 +1,150 @@
|
|||||||
|
PACKAGE=qt
|
||||||
|
$(package)_version=5.7.1
|
||||||
|
$(package)_download_path=http://download.qt.io/official_releases/qt/5.7/$($(package)_version)/submodules
|
||||||
|
$(package)_suffix=opensource-src-$($(package)_version).tar.gz
|
||||||
|
$(package)_file_name=qtbase-$($(package)_suffix)
|
||||||
|
$(package)_sha256_hash=95f83e532d23b3ddbde7973f380ecae1bac13230340557276f75f2e37984e410
|
||||||
|
$(package)_dependencies=openssl zlib
|
||||||
|
$(package)_build_subdir=qtbase
|
||||||
|
$(package)_qt_libs=corelib
|
||||||
|
$(package)_patches=pidlist_absolute.patch fix_qt_pkgconfig.patch qfixed-coretext.patch
|
||||||
|
|
||||||
|
$(package)_qttranslations_file_name=qttranslations-$($(package)_suffix)
|
||||||
|
$(package)_qttranslations_sha256_hash=3a15aebd523c6d89fb97b2d3df866c94149653a26d27a00aac9b6d3020bc5a1d
|
||||||
|
|
||||||
|
$(package)_qttools_file_name=qttools-$($(package)_suffix)
|
||||||
|
$(package)_qttools_sha256_hash=22d67de915cb8cd93e16fdd38fa006224ad9170bd217c2be1e53045a8dd02f0f
|
||||||
|
|
||||||
|
$(package)_extra_sources = $($(package)_qttranslations_file_name)
|
||||||
|
$(package)_extra_sources += $($(package)_qttools_file_name)
|
||||||
|
|
||||||
|
define $(package)_set_vars
|
||||||
|
$(package)_config_opts_release = -release
|
||||||
|
$(package)_config_opts_debug = -debug
|
||||||
|
$(package)_config_opts += -bindir $(build_prefix)/bin
|
||||||
|
$(package)_config_opts += -c++std c++11
|
||||||
|
$(package)_config_opts += -confirm-license
|
||||||
|
$(package)_config_opts += -dbus-runtime
|
||||||
|
$(package)_config_opts += -no-alsa
|
||||||
|
$(package)_config_opts += -no-audio-backend
|
||||||
|
$(package)_config_opts += -no-cups
|
||||||
|
$(package)_config_opts += -no-egl
|
||||||
|
$(package)_config_opts += -no-eglfs
|
||||||
|
$(package)_config_opts += -no-feature-style-windowsmobile
|
||||||
|
$(package)_config_opts += -no-feature-style-windowsce
|
||||||
|
$(package)_config_opts += -no-freetype
|
||||||
|
$(package)_config_opts += -no-gif
|
||||||
|
$(package)_config_opts += -no-glib
|
||||||
|
$(package)_config_opts += -no-gstreamer
|
||||||
|
$(package)_config_opts += -no-icu
|
||||||
|
$(package)_config_opts += -no-iconv
|
||||||
|
$(package)_config_opts += -no-kms
|
||||||
|
$(package)_config_opts += -no-linuxfb
|
||||||
|
$(package)_config_opts += -no-libudev
|
||||||
|
$(package)_config_opts += -no-mitshm
|
||||||
|
$(package)_config_opts += -no-mtdev
|
||||||
|
$(package)_config_opts += -no-pulseaudio
|
||||||
|
$(package)_config_opts += -no-openvg
|
||||||
|
$(package)_config_opts += -no-reduce-relocations
|
||||||
|
$(package)_config_opts += -no-qml-debug
|
||||||
|
$(package)_config_opts += -no-sql-db2
|
||||||
|
$(package)_config_opts += -no-sql-ibase
|
||||||
|
$(package)_config_opts += -no-sql-oci
|
||||||
|
$(package)_config_opts += -no-sql-tds
|
||||||
|
$(package)_config_opts += -no-sql-mysql
|
||||||
|
$(package)_config_opts += -no-sql-odbc
|
||||||
|
$(package)_config_opts += -no-sql-psql
|
||||||
|
$(package)_config_opts += -no-sql-sqlite
|
||||||
|
$(package)_config_opts += -no-sql-sqlite2
|
||||||
|
$(package)_config_opts += -no-use-gold-linker
|
||||||
|
$(package)_config_opts += -no-xinput2
|
||||||
|
$(package)_config_opts += -no-xrender
|
||||||
|
$(package)_config_opts += -nomake examples
|
||||||
|
$(package)_config_opts += -nomake tests
|
||||||
|
$(package)_config_opts += -opensource
|
||||||
|
$(package)_config_opts += -openssl-linked
|
||||||
|
$(package)_config_opts += -optimized-qmake
|
||||||
|
$(package)_config_opts += -pch
|
||||||
|
$(package)_config_opts += -pkg-config
|
||||||
|
$(package)_config_opts += -qt-libpng
|
||||||
|
$(package)_config_opts += -qt-libjpeg
|
||||||
|
$(package)_config_opts += -qt-pcre
|
||||||
|
$(package)_config_opts += -system-zlib
|
||||||
|
$(package)_config_opts += -reduce-exports
|
||||||
|
$(package)_config_opts += -static
|
||||||
|
$(package)_config_opts += -silent
|
||||||
|
$(package)_config_opts += -v
|
||||||
|
$(package)_config_opts += -no-feature-printer
|
||||||
|
$(package)_config_opts += -no-feature-printdialog
|
||||||
|
$(package)_config_opts += -no-gui
|
||||||
|
$(package)_config_opts += -no-freetype
|
||||||
|
$(package)_config_opts += -no-sm
|
||||||
|
$(package)_config_opts += -no-fontconfig
|
||||||
|
$(package)_config_opts += -no-opengl
|
||||||
|
$(package)_config_opts += -no-xkb
|
||||||
|
$(package)_config_opts += -no-xcb
|
||||||
|
$(package)_config_opts += -no-xshape
|
||||||
|
$(package)_build_env = QT_RCC_TEST=1
|
||||||
|
endef
|
||||||
|
|
||||||
|
define $(package)_fetch_cmds
|
||||||
|
$(call fetch_file,$(package),$($(package)_download_path),$($(package)_download_file),$($(package)_file_name),$($(package)_sha256_hash)) && \
|
||||||
|
$(call fetch_file,$(package),$($(package)_download_path),$($(package)_qttranslations_file_name),$($(package)_qttranslations_file_name),$($(package)_qttranslations_sha256_hash)) && \
|
||||||
|
$(call fetch_file,$(package),$($(package)_download_path),$($(package)_qttools_file_name),$($(package)_qttools_file_name),$($(package)_qttools_sha256_hash))
|
||||||
|
endef
|
||||||
|
|
||||||
|
define $(package)_extract_cmds
|
||||||
|
mkdir -p $($(package)_extract_dir) && \
|
||||||
|
echo "$($(package)_sha256_hash) $($(package)_source)" > $($(package)_extract_dir)/.$($(package)_file_name).hash && \
|
||||||
|
echo "$($(package)_qttranslations_sha256_hash) $($(package)_source_dir)/$($(package)_qttranslations_file_name)" >> $($(package)_extract_dir)/.$($(package)_file_name).hash && \
|
||||||
|
echo "$($(package)_qttools_sha256_hash) $($(package)_source_dir)/$($(package)_qttools_file_name)" >> $($(package)_extract_dir)/.$($(package)_file_name).hash && \
|
||||||
|
$(build_SHA256SUM) -c $($(package)_extract_dir)/.$($(package)_file_name).hash && \
|
||||||
|
mkdir qtbase && \
|
||||||
|
tar --strip-components=1 -xf $($(package)_source) -C qtbase && \
|
||||||
|
mkdir qttranslations && \
|
||||||
|
tar --strip-components=1 -xf $($(package)_source_dir)/$($(package)_qttranslations_file_name) -C qttranslations && \
|
||||||
|
mkdir qttools && \
|
||||||
|
tar --strip-components=1 -xf $($(package)_source_dir)/$($(package)_qttools_file_name) -C qttools
|
||||||
|
endef
|
||||||
|
|
||||||
|
|
||||||
|
define $(package)_preprocess_cmds
|
||||||
|
sed -i.old "s|updateqm.commands = \$$$$\$$$$LRELEASE|updateqm.commands = $($(package)_extract_dir)/qttools/bin/lrelease|" qttranslations/translations/translations.pro && \
|
||||||
|
sed -i.old "/updateqm.depends =/d" qttranslations/translations/translations.pro && \
|
||||||
|
patch -p1 < $($(package)_patch_dir)/pidlist_absolute.patch && \
|
||||||
|
patch -p1 < $($(package)_patch_dir)/fix_qt_pkgconfig.patch && \
|
||||||
|
patch -p1 < $($(package)_patch_dir)/qfixed-coretext.patch && \
|
||||||
|
echo "!host_build: QMAKE_CFLAGS += $($(package)_cflags) $($(package)_cppflags)" >> qtbase/mkspecs/common/gcc-base.conf && \
|
||||||
|
echo "!host_build: QMAKE_CXXFLAGS += $($(package)_cxxflags) $($(package)_cppflags)" >> qtbase/mkspecs/common/gcc-base.conf && \
|
||||||
|
echo "!host_build: QMAKE_LFLAGS += $($(package)_ldflags)" >> qtbase/mkspecs/common/gcc-base.conf
|
||||||
|
endef
|
||||||
|
|
||||||
|
define $(package)_config_cmds
|
||||||
|
export PKG_CONFIG_SYSROOT_DIR=/ && \
|
||||||
|
export PKG_CONFIG_LIBDIR=$(host_prefix)/lib/pkgconfig && \
|
||||||
|
export PKG_CONFIG_PATH=$(host_prefix)/share/pkgconfig && \
|
||||||
|
./configure $($(package)_config_opts) && \
|
||||||
|
echo "host_build: QT_CONFIG ~= s/system-zlib/zlib" >> mkspecs/qconfig.pri && \
|
||||||
|
echo "CONFIG += force_bootstrap" >> mkspecs/qconfig.pri && \
|
||||||
|
$(MAKE) sub-src-clean && \
|
||||||
|
cd ../qttranslations && ../qtbase/bin/qmake qttranslations.pro -o Makefile && \
|
||||||
|
cd translations && ../../qtbase/bin/qmake translations.pro -o Makefile && cd ../.. &&\
|
||||||
|
cd qttools/src/linguist/lrelease/ && ../../../../qtbase/bin/qmake lrelease.pro -o Makefile
|
||||||
|
endef
|
||||||
|
|
||||||
|
define $(package)_build_cmds
|
||||||
|
$(MAKE) -C src $(addprefix sub-,$($(package)_qt_libs)) && \
|
||||||
|
$(MAKE) -C ../qttools/src/linguist/lrelease && \
|
||||||
|
$(MAKE) -C ../qttranslations
|
||||||
|
endef
|
||||||
|
|
||||||
|
define $(package)_stage_cmds
|
||||||
|
$(MAKE) -C src INSTALL_ROOT=$($(package)_staging_dir) $(addsuffix -install_subtargets,$(addprefix sub-,$($(package)_qt_libs))) && cd .. &&\
|
||||||
|
$(MAKE) -C qttools/src/linguist/lrelease INSTALL_ROOT=$($(package)_staging_dir) install_target && \
|
||||||
|
$(MAKE) -C qttranslations INSTALL_ROOT=$($(package)_staging_dir) install_subtargets
|
||||||
|
endef
|
||||||
|
|
||||||
|
define $(package)_postprocess_cmds
|
||||||
|
rm -rf native/mkspecs/ native/lib/ lib/cmake/ && \
|
||||||
|
rm -f lib/lib*.la lib/*.prl plugins/*/*.prl
|
||||||
|
endef
|
33
contrib/depends/packages/readline.mk
Normal file
33
contrib/depends/packages/readline.mk
Normal file
@ -0,0 +1,33 @@
|
|||||||
|
package=readline
|
||||||
|
$(package)_version=6.3
|
||||||
|
$(package)_download_path=ftp://ftp.cwru.edu/pub/bash/
|
||||||
|
$(package)_file_name=$(package)-$($(package)_version).tar.gz
|
||||||
|
$(package)_sha256_hash=56ba6071b9462f980c5a72ab0023893b65ba6debb4eeb475d7a563dc65cafd43
|
||||||
|
$(package)_patches=readline-1.patch
|
||||||
|
|
||||||
|
define $(package)_set_vars
|
||||||
|
$(package)_build_opts=CC="$($(package)_cc)"
|
||||||
|
$(package)_config_env=AR="$($(package)_ar)" RANLIB="$($(package)_ranlib)" CC="$($(package)_cc)"
|
||||||
|
$(package)_config_opts=--prefix=$(host_prefix)
|
||||||
|
$(package)_config_opts+=--disable-shared --enable-multibye --without-purify --without-curses
|
||||||
|
$(package)_config_opts_release=--disable-debug-mode
|
||||||
|
$(package)_build_opts=CFLAGS="$($(package)_cflags) $($(package)_cppflags) -fPIC"
|
||||||
|
endef
|
||||||
|
|
||||||
|
define $(package)_config_cmds
|
||||||
|
patch -p1 < $($(package)_patch_dir)/readline-1.patch &&\
|
||||||
|
export bash_cv_have_mbstate_t=yes &&\
|
||||||
|
export bash_cv_wcwidth_broken=yes &&\
|
||||||
|
./configure $($(package)_config_opts)
|
||||||
|
endef
|
||||||
|
|
||||||
|
define $(package)_build_cmds
|
||||||
|
$(MAKE) $($(package)_build_opts)
|
||||||
|
endef
|
||||||
|
|
||||||
|
define $(package)_stage_cmds
|
||||||
|
$(MAKE) DESTDIR=$($(package)_staging_dir) install
|
||||||
|
endef
|
||||||
|
|
||||||
|
define $(package)_postprocess_cmds
|
||||||
|
endef
|
23
contrib/depends/packages/sodium.mk
Normal file
23
contrib/depends/packages/sodium.mk
Normal file
@ -0,0 +1,23 @@
|
|||||||
|
package=sodium
|
||||||
|
$(package)_version=1.0.16
|
||||||
|
$(package)_download_path=https://github.com/jedisct1/libsodium/archive
|
||||||
|
$(package)_file_name=$($(package)_version).tar.gz
|
||||||
|
$(package)_sha256_hash=0c14604bbeab2e82a803215d65c3b6e74bb28291aaee6236d65c699ccfe1a98c
|
||||||
|
|
||||||
|
define $(package)_set_vars
|
||||||
|
$(package)_config_opts=--enable-static
|
||||||
|
$(package)_config_opts+=--prefix=$(host_prefix)
|
||||||
|
endef
|
||||||
|
|
||||||
|
define $(package)_config_cmds
|
||||||
|
./autogen.sh &&\
|
||||||
|
$($(package)_autoconf) $($(package)_config_opts)
|
||||||
|
endef
|
||||||
|
|
||||||
|
define $(package)_build_cmds
|
||||||
|
$(MAKE)
|
||||||
|
endef
|
||||||
|
|
||||||
|
define $(package)_stage_cmds
|
||||||
|
$(MAKE) DESTDIR=$($(package)_staging_dir) install
|
||||||
|
endef
|
28
contrib/depends/packages/unbound.mk
Normal file
28
contrib/depends/packages/unbound.mk
Normal file
@ -0,0 +1,28 @@
|
|||||||
|
package=unbound
|
||||||
|
$(package)_version=1.6.8
|
||||||
|
$(package)_download_path=http://www.unbound.net/downloads/
|
||||||
|
$(package)_file_name=$(package)-$($(package)_version).tar.gz
|
||||||
|
$(package)_sha256_hash=e3b428e33f56a45417107448418865fe08d58e0e7fea199b855515f60884dd49
|
||||||
|
$(package)_dependencies=openssl expat ldns
|
||||||
|
|
||||||
|
define $(package)_set_vars
|
||||||
|
$(package)_config_opts=--disable-shared --enable-static --without-pyunbound --prefix=$(host_prefix) --with-libexpat=$(host_prefix) --with-ssl=$(host_prefix) --with-libevent=no --without-pythonmodule --disable-flto --with-pthreads
|
||||||
|
$(package)_config_opts_linux=--with-pic
|
||||||
|
$(package)_config_opts_w64=--enable-static-exe --sysconfdir=/etc --prefix=$(host_prefix) --target=$(host_prefix)
|
||||||
|
$(package)_build_opts_mingw32=LDFLAGS="$($(package)_ldflags) -lpthread"
|
||||||
|
endef
|
||||||
|
|
||||||
|
define $(package)_config_cmds
|
||||||
|
$($(package)_autoconf) $($(package)_config_opts)
|
||||||
|
endef
|
||||||
|
|
||||||
|
define $(package)_build_cmds
|
||||||
|
$(MAKE) $($(package)_build_opts)
|
||||||
|
endef
|
||||||
|
|
||||||
|
define $(package)_stage_cmds
|
||||||
|
$(MAKE) DESTDIR=$($(package)_staging_dir) install
|
||||||
|
endef
|
||||||
|
|
||||||
|
define $(package)_postprocess_cmds
|
||||||
|
endef
|
22
contrib/depends/packages/unwind.mk
Normal file
22
contrib/depends/packages/unwind.mk
Normal file
@ -0,0 +1,22 @@
|
|||||||
|
package=unwind
|
||||||
|
$(package)_version=1.2
|
||||||
|
$(package)_download_path=http://download.savannah.nongnu.org/releases/libunwind
|
||||||
|
$(package)_file_name=lib$(package)-$($(package)_version).tar.gz
|
||||||
|
$(package)_sha256_hash=1de38ffbdc88bd694d10081865871cd2bfbb02ad8ef9e1606aee18d65532b992
|
||||||
|
|
||||||
|
define $(package)_config_cmds
|
||||||
|
cp -f $(BASEDIR)/config.guess config/config.guess &&\
|
||||||
|
cp -f $(BASEDIR)/config.sub config/config.sub &&\
|
||||||
|
$($(package)_autoconf) --disable-shared --enable-static
|
||||||
|
endef
|
||||||
|
|
||||||
|
define $(package)_build_cmds
|
||||||
|
$(MAKE)
|
||||||
|
endef
|
||||||
|
|
||||||
|
define $(package)_stage_cmds
|
||||||
|
$(MAKE) DESTDIR=$($(package)_staging_dir) install
|
||||||
|
endef
|
||||||
|
|
||||||
|
define $(package)_postprocess_cmds
|
||||||
|
endef
|
21
contrib/depends/packages/xproto.mk
Normal file
21
contrib/depends/packages/xproto.mk
Normal file
@ -0,0 +1,21 @@
|
|||||||
|
package=xproto
|
||||||
|
$(package)_version=7.0.26
|
||||||
|
$(package)_download_path=http://xorg.freedesktop.org/releases/individual/proto
|
||||||
|
$(package)_file_name=$(package)-$($(package)_version).tar.bz2
|
||||||
|
$(package)_sha256_hash=636162c1759805a5a0114a369dffdeccb8af8c859ef6e1445f26a4e6e046514f
|
||||||
|
|
||||||
|
define $(package)_set_vars
|
||||||
|
$(package)_config_opts=--disable-shared
|
||||||
|
endef
|
||||||
|
|
||||||
|
define $(package)_config_cmds
|
||||||
|
$($(package)_autoconf)
|
||||||
|
endef
|
||||||
|
|
||||||
|
define $(package)_build_cmds
|
||||||
|
$(MAKE)
|
||||||
|
endef
|
||||||
|
|
||||||
|
define $(package)_stage_cmds
|
||||||
|
$(MAKE) DESTDIR=$($(package)_staging_dir) install
|
||||||
|
endef
|
34
contrib/depends/packages/zeromq.mk
Normal file
34
contrib/depends/packages/zeromq.mk
Normal file
@ -0,0 +1,34 @@
|
|||||||
|
package=zeromq
|
||||||
|
$(package)_version=4.1.5
|
||||||
|
$(package)_download_path=https://github.com/zeromq/zeromq4-1/releases/download/v$($(package)_version)/
|
||||||
|
$(package)_file_name=$(package)-$($(package)_version).tar.gz
|
||||||
|
$(package)_sha256_hash=04aac57f081ffa3a2ee5ed04887be9e205df3a7ddade0027460b8042432bdbcf
|
||||||
|
$(package)_patches=9114d3957725acd34aa8b8d011585812f3369411.patch 9e6745c12e0b100cd38acecc16ce7db02905e27c.patch
|
||||||
|
|
||||||
|
define $(package)_set_vars
|
||||||
|
$(package)_config_opts=--without-documentation --disable-shared --without-libsodium --disable-curve
|
||||||
|
$(package)_config_opts_linux=--with-pic
|
||||||
|
$(package)_cxxflags=-std=c++11
|
||||||
|
endef
|
||||||
|
|
||||||
|
define $(package)_preprocess_cmds
|
||||||
|
patch -p1 < $($(package)_patch_dir)/9114d3957725acd34aa8b8d011585812f3369411.patch && \
|
||||||
|
patch -p1 < $($(package)_patch_dir)/9e6745c12e0b100cd38acecc16ce7db02905e27c.patch && \
|
||||||
|
./autogen.sh
|
||||||
|
endef
|
||||||
|
|
||||||
|
define $(package)_config_cmds
|
||||||
|
$($(package)_autoconf)
|
||||||
|
endef
|
||||||
|
|
||||||
|
define $(package)_build_cmds
|
||||||
|
$(MAKE) libzmq.la
|
||||||
|
endef
|
||||||
|
|
||||||
|
define $(package)_stage_cmds
|
||||||
|
$(MAKE) DESTDIR=$($(package)_staging_dir) install-libLTLIBRARIES install-includeHEADERS install-pkgconfigDATA
|
||||||
|
endef
|
||||||
|
|
||||||
|
define $(package)_postprocess_cmds
|
||||||
|
rm -rf bin share
|
||||||
|
endef
|
27
contrib/depends/packages/zlib.mk
Normal file
27
contrib/depends/packages/zlib.mk
Normal file
@ -0,0 +1,27 @@
|
|||||||
|
package=zlib
|
||||||
|
$(package)_version=1.2.11
|
||||||
|
$(package)_download_path=http://www.zlib.net
|
||||||
|
$(package)_file_name=$(package)-$($(package)_version).tar.gz
|
||||||
|
$(package)_sha256_hash=c3e5e9fdd5004dcb542feda5ee4f0ff0744628baf8ed2dd5d66f8ca1197cb1a1
|
||||||
|
|
||||||
|
define $(package)_set_vars
|
||||||
|
$(package)_build_opts= CC="$($(package)_cc)"
|
||||||
|
$(package)_build_opts+=CFLAGS="$($(package)_cflags) $($(package)_cppflags) -fPIC"
|
||||||
|
$(package)_build_opts+=RANLIB="$($(package)_ranlib)"
|
||||||
|
$(package)_build_opts+=AR="$($(package)_ar)"
|
||||||
|
$(package)_build_opts_darwin+=AR="$($(package)_libtool)"
|
||||||
|
$(package)_build_opts_darwin+=ARFLAGS="-o"
|
||||||
|
endef
|
||||||
|
|
||||||
|
define $(package)_config_cmds
|
||||||
|
./configure --static --prefix=$(host_prefix)
|
||||||
|
endef
|
||||||
|
|
||||||
|
define $(package)_build_cmds
|
||||||
|
$(MAKE) $($(package)_build_opts) libz.a
|
||||||
|
endef
|
||||||
|
|
||||||
|
define $(package)_stage_cmds
|
||||||
|
$(MAKE) DESTDIR=$($(package)_staging_dir) install $($(package)_build_opts)
|
||||||
|
endef
|
||||||
|
|
67
contrib/depends/patches/cmake/cmake-1-fixes.patch
Normal file
67
contrib/depends/patches/cmake/cmake-1-fixes.patch
Normal file
@ -0,0 +1,67 @@
|
|||||||
|
This file is part of MXE. See LICENSE.md for licensing information.
|
||||||
|
|
||||||
|
Contains ad hoc patches for cross building.
|
||||||
|
|
||||||
|
From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001
|
||||||
|
From: Tony Theodore <tonyt@logyst.com>
|
||||||
|
Date: Fri, 12 Aug 2016 02:01:20 +1000
|
||||||
|
Subject: [PATCH 1/3] fix windres invocation options
|
||||||
|
|
||||||
|
windres doesn't recognise various gcc flags like -mms-bitfields,
|
||||||
|
-fopenmp, -mthreads etc. (basically not `-D` or `-I`)
|
||||||
|
|
||||||
|
diff --git a/Modules/Platform/Windows-windres.cmake b/Modules/Platform/Windows-windres.cmake
|
||||||
|
index 1111111..2222222 100644
|
||||||
|
--- a/Modules/Platform/Windows-windres.cmake
|
||||||
|
+++ b/Modules/Platform/Windows-windres.cmake
|
||||||
|
@@ -1 +1 @@
|
||||||
|
-set(CMAKE_RC_COMPILE_OBJECT "<CMAKE_RC_COMPILER> -O coff <DEFINES> <INCLUDES> <FLAGS> <SOURCE> <OBJECT>")
|
||||||
|
+set(CMAKE_RC_COMPILE_OBJECT "<CMAKE_RC_COMPILER> -O coff <DEFINES> <INCLUDES> <SOURCE> <OBJECT>")
|
||||||
|
|
||||||
|
From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001
|
||||||
|
From: Tony Theodore <tonyt@logyst.com>
|
||||||
|
Date: Tue, 25 Jul 2017 20:34:56 +1000
|
||||||
|
Subject: [PATCH 2/3] add option to disable -isystem
|
||||||
|
|
||||||
|
taken from (not accepted):
|
||||||
|
https://gitlab.kitware.com/cmake/cmake/merge_requests/895
|
||||||
|
|
||||||
|
see also:
|
||||||
|
https://gitlab.kitware.com/cmake/cmake/issues/16291
|
||||||
|
https://gitlab.kitware.com/cmake/cmake/issues/16919
|
||||||
|
|
||||||
|
diff --git a/Modules/Compiler/GNU.cmake b/Modules/Compiler/GNU.cmake
|
||||||
|
index 1111111..2222222 100644
|
||||||
|
--- a/Modules/Compiler/GNU.cmake
|
||||||
|
+++ b/Modules/Compiler/GNU.cmake
|
||||||
|
@@ -42,7 +42,7 @@ macro(__compiler_gnu lang)
|
||||||
|
string(APPEND CMAKE_${lang}_FLAGS_RELWITHDEBINFO_INIT " -O2 -g -DNDEBUG")
|
||||||
|
set(CMAKE_${lang}_CREATE_PREPROCESSED_SOURCE "<CMAKE_${lang}_COMPILER> <DEFINES> <INCLUDES> <FLAGS> -E <SOURCE> > <PREPROCESSED_SOURCE>")
|
||||||
|
set(CMAKE_${lang}_CREATE_ASSEMBLY_SOURCE "<CMAKE_${lang}_COMPILER> <DEFINES> <INCLUDES> <FLAGS> -S <SOURCE> -o <ASSEMBLY_SOURCE>")
|
||||||
|
- if(NOT APPLE OR NOT CMAKE_${lang}_COMPILER_VERSION VERSION_LESS 4) # work around #4462
|
||||||
|
+ if(NOT APPLE OR NOT CMAKE_${lang}_COMPILER_VERSION VERSION_LESS 4 AND (NOT MXE_DISABLE_INCLUDE_SYSTEM_FLAG)) # work around #4462
|
||||||
|
set(CMAKE_INCLUDE_SYSTEM_FLAG_${lang} "-isystem ")
|
||||||
|
endif()
|
||||||
|
endmacro()
|
||||||
|
|
||||||
|
From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001
|
||||||
|
From: Tony Theodore <tonyt@logyst.com>
|
||||||
|
Date: Tue, 15 Aug 2017 15:25:06 +1000
|
||||||
|
Subject: [PATCH 3/3] add CPACK_NSIS_EXECUTABLE variable
|
||||||
|
|
||||||
|
|
||||||
|
diff --git a/Source/CPack/cmCPackNSISGenerator.cxx b/Source/CPack/cmCPackNSISGenerator.cxx
|
||||||
|
index 1111111..2222222 100644
|
||||||
|
--- a/Source/CPack/cmCPackNSISGenerator.cxx
|
||||||
|
+++ b/Source/CPack/cmCPackNSISGenerator.cxx
|
||||||
|
@@ -384,7 +384,9 @@ int cmCPackNSISGenerator::InitializeInternal()
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
|
- nsisPath = cmSystemTools::FindProgram("makensis", path, false);
|
||||||
|
+ this->SetOptionIfNotSet("CPACK_NSIS_EXECUTABLE", "makensis");
|
||||||
|
+ nsisPath = cmSystemTools::FindProgram(
|
||||||
|
+ this->GetOption("CPACK_NSIS_EXECUTABLE"), path, false);
|
||||||
|
|
||||||
|
if (nsisPath.empty()) {
|
||||||
|
cmCPackLogger(
|
@ -0,0 +1,37 @@
|
|||||||
|
Don't build object files twice
|
||||||
|
|
||||||
|
When passed --enable-static and --enable-shared, icu will generate
|
||||||
|
both a shared and a static version of its libraries.
|
||||||
|
|
||||||
|
However, in order to do so, it builds each and every object file
|
||||||
|
twice: once with -fPIC (for the shared library), and once without
|
||||||
|
-fPIC (for the static library). While admittedly building -fPIC for a
|
||||||
|
static library generates a slightly suboptimal code, this is what all
|
||||||
|
the autotools-based project are doing. They build each object file
|
||||||
|
once, and they use it for both the static and shared libraries.
|
||||||
|
|
||||||
|
icu builds the object files for the shared library as .o files, and
|
||||||
|
the object files for static library as .ao files. By simply changing
|
||||||
|
the suffix of object files used for static libraries to ".o", we tell
|
||||||
|
icu to use the ones built for the shared library (i.e, with -fPIC),
|
||||||
|
and avoid the double build of icu.
|
||||||
|
|
||||||
|
On a fast build server, this brings the target icu build from
|
||||||
|
3m41.302s down to 1m43.926s (approximate numbers: some other builds
|
||||||
|
are running on the system at the same time).
|
||||||
|
|
||||||
|
Signed-off-by: Thomas Petazzoni <thomas.petazzoni@free-electrons.com>
|
||||||
|
|
||||||
|
Index: b/source/config/mh-linux
|
||||||
|
===================================================================
|
||||||
|
--- a/source/config/mh-linux
|
||||||
|
+++ b/source/config/mh-linux
|
||||||
|
@@ -38,7 +38,7 @@
|
||||||
|
## Shared object suffix
|
||||||
|
SO = so
|
||||||
|
## Non-shared intermediate object suffix
|
||||||
|
-STATIC_O = ao
|
||||||
|
+STATIC_O = o
|
||||||
|
|
||||||
|
## Compilation rules
|
||||||
|
%.$(STATIC_O): $(srcdir)/%.c
|
29
contrib/depends/patches/native_biplist/sorted_list.patch
Normal file
29
contrib/depends/patches/native_biplist/sorted_list.patch
Normal file
@ -0,0 +1,29 @@
|
|||||||
|
--- a/biplist/__init__.py 2014-10-26 19:03:11.000000000 +0000
|
||||||
|
+++ b/biplist/__init__.py 2016-07-19 19:30:17.663521999 +0000
|
||||||
|
@@ -541,7 +541,7 @@
|
||||||
|
return HashableWrapper(n)
|
||||||
|
elif isinstance(root, dict):
|
||||||
|
n = {}
|
||||||
|
- for key, value in iteritems(root):
|
||||||
|
+ for key, value in sorted(iteritems(root)):
|
||||||
|
n[self.wrapRoot(key)] = self.wrapRoot(value)
|
||||||
|
return HashableWrapper(n)
|
||||||
|
elif isinstance(root, list):
|
||||||
|
@@ -616,7 +616,7 @@
|
||||||
|
elif isinstance(obj, dict):
|
||||||
|
size = proc_size(len(obj))
|
||||||
|
self.incrementByteCount('dictBytes', incr=1+size)
|
||||||
|
- for key, value in iteritems(obj):
|
||||||
|
+ for key, value in sorted(iteritems(obj)):
|
||||||
|
check_key(key)
|
||||||
|
self.computeOffsets(key, asReference=True)
|
||||||
|
self.computeOffsets(value, asReference=True)
|
||||||
|
@@ -714,7 +714,7 @@
|
||||||
|
keys = []
|
||||||
|
values = []
|
||||||
|
objectsToWrite = []
|
||||||
|
- for key, value in iteritems(obj):
|
||||||
|
+ for key, value in sorted(iteritems(obj)):
|
||||||
|
keys.append(key)
|
||||||
|
values.append(value)
|
||||||
|
for key in keys:
|
@ -0,0 +1,86 @@
|
|||||||
|
--- cdrkit-1.1.11.old/genisoimage/tree.c 2008-10-21 19:57:47.000000000 -0400
|
||||||
|
+++ cdrkit-1.1.11/genisoimage/tree.c 2013-12-06 00:23:18.489622668 -0500
|
||||||
|
@@ -1139,8 +1139,9 @@
|
||||||
|
scan_directory_tree(struct directory *this_dir, char *path,
|
||||||
|
struct directory_entry *de)
|
||||||
|
{
|
||||||
|
- DIR *current_dir;
|
||||||
|
+ int current_file;
|
||||||
|
char whole_path[PATH_MAX];
|
||||||
|
+ struct dirent **d_list;
|
||||||
|
struct dirent *d_entry;
|
||||||
|
struct directory *parent;
|
||||||
|
int dflag;
|
||||||
|
@@ -1164,7 +1165,8 @@
|
||||||
|
this_dir->dir_flags |= DIR_WAS_SCANNED;
|
||||||
|
|
||||||
|
errno = 0; /* Paranoia */
|
||||||
|
- current_dir = opendir(path);
|
||||||
|
+ //current_dir = opendir(path);
|
||||||
|
+ current_file = scandir(path, &d_list, NULL, alphasort);
|
||||||
|
d_entry = NULL;
|
||||||
|
|
||||||
|
/*
|
||||||
|
@@ -1173,12 +1175,12 @@
|
||||||
|
*/
|
||||||
|
old_path = path;
|
||||||
|
|
||||||
|
- if (current_dir) {
|
||||||
|
+ if (current_file >= 0) {
|
||||||
|
errno = 0;
|
||||||
|
- d_entry = readdir(current_dir);
|
||||||
|
+ d_entry = d_list[0];
|
||||||
|
}
|
||||||
|
|
||||||
|
- if (!current_dir || !d_entry) {
|
||||||
|
+ if (current_file < 0 || !d_entry) {
|
||||||
|
int ret = 1;
|
||||||
|
|
||||||
|
#ifdef USE_LIBSCHILY
|
||||||
|
@@ -1191,8 +1193,8 @@
|
||||||
|
de->isorec.flags[0] &= ~ISO_DIRECTORY;
|
||||||
|
ret = 0;
|
||||||
|
}
|
||||||
|
- if (current_dir)
|
||||||
|
- closedir(current_dir);
|
||||||
|
+ if(d_list)
|
||||||
|
+ free(d_list);
|
||||||
|
return (ret);
|
||||||
|
}
|
||||||
|
#ifdef ABORT_DEEP_ISO_ONLY
|
||||||
|
@@ -1208,7 +1210,7 @@
|
||||||
|
errmsgno(EX_BAD, "use Rock Ridge extensions via -R or -r,\n");
|
||||||
|
errmsgno(EX_BAD, "or allow deep ISO9660 directory nesting via -D.\n");
|
||||||
|
}
|
||||||
|
- closedir(current_dir);
|
||||||
|
+ free(d_list);
|
||||||
|
return (1);
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
@@ -1250,13 +1252,13 @@
|
||||||
|
* The first time through, skip this, since we already asked
|
||||||
|
* for the first entry when we opened the directory.
|
||||||
|
*/
|
||||||
|
- if (dflag)
|
||||||
|
- d_entry = readdir(current_dir);
|
||||||
|
+ if (dflag && current_file >= 0)
|
||||||
|
+ d_entry = d_list[current_file];
|
||||||
|
dflag++;
|
||||||
|
|
||||||
|
- if (!d_entry)
|
||||||
|
+ if (current_file < 0)
|
||||||
|
break;
|
||||||
|
-
|
||||||
|
+ current_file--;
|
||||||
|
/* OK, got a valid entry */
|
||||||
|
|
||||||
|
/* If we do not want all files, then pitch the backups. */
|
||||||
|
@@ -1348,7 +1350,7 @@
|
||||||
|
insert_file_entry(this_dir, whole_path, d_entry->d_name);
|
||||||
|
#endif /* APPLE_HYB */
|
||||||
|
}
|
||||||
|
- closedir(current_dir);
|
||||||
|
+ free(d_list);
|
||||||
|
|
||||||
|
#ifdef APPLE_HYB
|
||||||
|
/*
|
72
contrib/depends/patches/native_mac_alias/python3.patch
Normal file
72
contrib/depends/patches/native_mac_alias/python3.patch
Normal file
@ -0,0 +1,72 @@
|
|||||||
|
diff -dur a/mac_alias/alias.py b/mac_alias/alias.py
|
||||||
|
--- a/mac_alias/alias.py 2015-10-19 12:12:48.000000000 +0200
|
||||||
|
+++ b/mac_alias/alias.py 2016-04-03 12:13:12.037159417 +0200
|
||||||
|
@@ -243,10 +243,10 @@
|
||||||
|
alias = Alias()
|
||||||
|
alias.appinfo = appinfo
|
||||||
|
|
||||||
|
- alias.volume = VolumeInfo (volname.replace('/',':'),
|
||||||
|
+ alias.volume = VolumeInfo (volname.decode().replace('/',':'),
|
||||||
|
voldate, fstype, disktype,
|
||||||
|
volattrs, volfsid)
|
||||||
|
- alias.target = TargetInfo (kind, filename.replace('/',':'),
|
||||||
|
+ alias.target = TargetInfo (kind, filename.decode().replace('/',':'),
|
||||||
|
folder_cnid, cnid,
|
||||||
|
crdate, creator_code, type_code)
|
||||||
|
alias.target.levels_from = levels_from
|
||||||
|
@@ -261,9 +261,9 @@
|
||||||
|
b.read(1)
|
||||||
|
|
||||||
|
if tag == TAG_CARBON_FOLDER_NAME:
|
||||||
|
- alias.target.folder_name = value.replace('/',':')
|
||||||
|
+ alias.target.folder_name = value.decode().replace('/',':')
|
||||||
|
elif tag == TAG_CNID_PATH:
|
||||||
|
- alias.target.cnid_path = struct.unpack(b'>%uI' % (length // 4),
|
||||||
|
+ alias.target.cnid_path = struct.unpack('>%uI' % (length // 4),
|
||||||
|
value)
|
||||||
|
elif tag == TAG_CARBON_PATH:
|
||||||
|
alias.target.carbon_path = value
|
||||||
|
@@ -298,9 +298,9 @@
|
||||||
|
alias.target.creation_date \
|
||||||
|
= mac_epoch + datetime.timedelta(seconds=seconds)
|
||||||
|
elif tag == TAG_POSIX_PATH:
|
||||||
|
- alias.target.posix_path = value
|
||||||
|
+ alias.target.posix_path = value.decode()
|
||||||
|
elif tag == TAG_POSIX_PATH_TO_MOUNTPOINT:
|
||||||
|
- alias.volume.posix_path = value
|
||||||
|
+ alias.volume.posix_path = value.decode()
|
||||||
|
elif tag == TAG_RECURSIVE_ALIAS_OF_DISK_IMAGE:
|
||||||
|
alias.volume.disk_image_alias = Alias.from_bytes(value)
|
||||||
|
elif tag == TAG_USER_HOME_LENGTH_PREFIX:
|
||||||
|
@@ -422,13 +422,13 @@
|
||||||
|
# (so doing so is ridiculous, and nothing could rely on it).
|
||||||
|
b.write(struct.pack(b'>h28pI2shI64pII4s4shhI2s10s',
|
||||||
|
self.target.kind,
|
||||||
|
- carbon_volname, voldate,
|
||||||
|
+ carbon_volname, int(voldate),
|
||||||
|
self.volume.fs_type,
|
||||||
|
self.volume.disk_type,
|
||||||
|
self.target.folder_cnid,
|
||||||
|
carbon_filename,
|
||||||
|
self.target.cnid,
|
||||||
|
- crdate,
|
||||||
|
+ int(crdate),
|
||||||
|
self.target.creator_code,
|
||||||
|
self.target.type_code,
|
||||||
|
self.target.levels_from,
|
||||||
|
@@ -449,12 +449,12 @@
|
||||||
|
|
||||||
|
b.write(struct.pack(b'>hhQhhQ',
|
||||||
|
TAG_HIGH_RES_VOLUME_CREATION_DATE,
|
||||||
|
- 8, long(voldate * 65536),
|
||||||
|
+ 8, int(voldate * 65536),
|
||||||
|
TAG_HIGH_RES_CREATION_DATE,
|
||||||
|
- 8, long(crdate * 65536)))
|
||||||
|
+ 8, int(crdate * 65536)))
|
||||||
|
|
||||||
|
if self.target.cnid_path:
|
||||||
|
- cnid_path = struct.pack(b'>%uI' % len(self.target.cnid_path),
|
||||||
|
+ cnid_path = struct.pack('>%uI' % len(self.target.cnid_path),
|
||||||
|
*self.target.cnid_path)
|
||||||
|
b.write(struct.pack(b'>hh', TAG_CNID_PATH,
|
||||||
|
len(cnid_path)))
|
11
contrib/depends/patches/qt/fix_qt_pkgconfig.patch
Normal file
11
contrib/depends/patches/qt/fix_qt_pkgconfig.patch
Normal file
@ -0,0 +1,11 @@
|
|||||||
|
--- old/qtbase/mkspecs/features/qt_module.prf
|
||||||
|
+++ new/qtbase/mkspecs/features/qt_module.prf
|
||||||
|
@@ -245,7 +245,7 @@
|
||||||
|
load(qt_targets)
|
||||||
|
|
||||||
|
# this builds on top of qt_common
|
||||||
|
-!internal_module:!lib_bundle:if(unix|mingw) {
|
||||||
|
+unix|mingw {
|
||||||
|
CONFIG += create_pc
|
||||||
|
QMAKE_PKGCONFIG_DESTDIR = pkgconfig
|
||||||
|
host_build: \
|
37
contrib/depends/patches/qt/pidlist_absolute.patch
Normal file
37
contrib/depends/patches/qt/pidlist_absolute.patch
Normal file
@ -0,0 +1,37 @@
|
|||||||
|
diff -dur old/qtbase/src/plugins/platforms/windows/qwindowscontext.h new/qtbase/src/plugins/platforms/windows/qwindowscontext.h
|
||||||
|
--- old/qtbase/src/plugins/platforms/windows/qwindowscontext.h
|
||||||
|
+++ new/qtbase/src/plugins/platforms/windows/qwindowscontext.h
|
||||||
|
@@ -136,10 +136,18 @@
|
||||||
|
inline void init();
|
||||||
|
|
||||||
|
typedef HRESULT (WINAPI *SHCreateItemFromParsingName)(PCWSTR, IBindCtx *, const GUID&, void **);
|
||||||
|
+#if defined(Q_CC_MINGW) && (!defined(__MINGW64_VERSION_MAJOR) || __MINGW64_VERSION_MAJOR < 3)
|
||||||
|
+ typedef HRESULT (WINAPI *SHGetKnownFolderIDList)(const GUID &, DWORD, HANDLE, ITEMIDLIST **);
|
||||||
|
+#else
|
||||||
|
typedef HRESULT (WINAPI *SHGetKnownFolderIDList)(const GUID &, DWORD, HANDLE, PIDLIST_ABSOLUTE *);
|
||||||
|
+#endif
|
||||||
|
typedef HRESULT (WINAPI *SHGetStockIconInfo)(int , int , _SHSTOCKICONINFO *);
|
||||||
|
typedef HRESULT (WINAPI *SHGetImageList)(int, REFIID , void **);
|
||||||
|
+#if defined(Q_CC_MINGW) && (!defined(__MINGW64_VERSION_MAJOR) || __MINGW64_VERSION_MAJOR < 3)
|
||||||
|
+ typedef HRESULT (WINAPI *SHCreateItemFromIDList)(const ITEMIDLIST *, REFIID, void **);
|
||||||
|
+#else
|
||||||
|
typedef HRESULT (WINAPI *SHCreateItemFromIDList)(PCIDLIST_ABSOLUTE, REFIID, void **);
|
||||||
|
+#endif
|
||||||
|
|
||||||
|
SHCreateItemFromParsingName sHCreateItemFromParsingName;
|
||||||
|
SHGetKnownFolderIDList sHGetKnownFolderIDList;
|
||||||
|
diff -dur old/qtbase/src/plugins/platforms/windows/qwindowsdialoghelpers.cpp new/qtbase/src/plugins/platforms/windows/qwindowsdialoghelpers.cpp
|
||||||
|
--- old/qtbase/src/plugins/platforms/windows/qwindowsdialoghelpers.cpp
|
||||||
|
+++ new/qtbase/src/plugins/platforms/windows/qwindowsdialoghelpers.cpp
|
||||||
|
@@ -1016,7 +1016,11 @@
|
||||||
|
qWarning() << __FUNCTION__ << ": Invalid CLSID: " << url.path();
|
||||||
|
return Q_NULLPTR;
|
||||||
|
}
|
||||||
|
+#if defined(Q_CC_MINGW) && (!defined(__MINGW64_VERSION_MAJOR) || __MINGW64_VERSION_MAJOR < 3)
|
||||||
|
+ ITEMIDLIST *idList;
|
||||||
|
+#else
|
||||||
|
PIDLIST_ABSOLUTE idList;
|
||||||
|
+#endif
|
||||||
|
HRESULT hr = QWindowsContext::shell32dll.sHGetKnownFolderIDList(uuid, 0, 0, &idList);
|
||||||
|
if (FAILED(hr)) {
|
||||||
|
qErrnoWarning("%s: SHGetKnownFolderIDList(%s)) failed", __FUNCTION__, qPrintable(url.toString()));
|
34
contrib/depends/patches/qt/qfixed-coretext.patch
Normal file
34
contrib/depends/patches/qt/qfixed-coretext.patch
Normal file
@ -0,0 +1,34 @@
|
|||||||
|
From dbdd5f0ffbce52c8b789ed09f1aa3f1da6c02e23 Mon Sep 17 00:00:00 2001
|
||||||
|
From: Gabriel de Dietrich <gabriel.dedietrich@qt.io>
|
||||||
|
Date: Fri, 30 Mar 2018 11:58:16 -0700
|
||||||
|
Subject: [PATCH] QCoreTextFontEngine: Fix build with Xcode 9.3
|
||||||
|
|
||||||
|
Apple LLVM version 9.1.0 (clang-902.0.39.1)
|
||||||
|
|
||||||
|
Error message:
|
||||||
|
|
||||||
|
.../qfontengine_coretext.mm:827:20: error: qualified reference to
|
||||||
|
'QFixed' is a constructor name rather than a type in this context
|
||||||
|
return QFixed::QFixed(int(CTFontGetUnitsPerEm(ctfont)));
|
||||||
|
|
||||||
|
Change-Id: Iebe26b3b087a16b10664208fc8851cbddb47f043
|
||||||
|
Reviewed-by: Konstantin Ritt <ritt.ks@gmail.com>
|
||||||
|
---
|
||||||
|
src/platformsupport/fontdatabases/mac/qfontengine_coretext.mm | 2 +-
|
||||||
|
1 file changed, 1 insertion(+), 1 deletion(-)
|
||||||
|
|
||||||
|
diff --git old/qtbase/src/platformsupport/fontdatabases/mac/qfontengine_coretext.mm new/qtbase/src/platformsupport/fontdatabases/mac/qfontengine_coretext.mm
|
||||||
|
index 25ff69d877d..98b753eff96 100644
|
||||||
|
--- old/qtbase/src/platformsupport/fontdatabases/mac/qfontengine_coretext.mm
|
||||||
|
+++ new/qtbase/src/platformsupport/fontdatabases/mac/qfontengine_coretext.mm
|
||||||
|
@@ -824,7 +824,7 @@ void QCoreTextFontEngine::getUnscaledGlyph(glyph_t glyph, QPainterPath *path, gl
|
||||||
|
|
||||||
|
QFixed QCoreTextFontEngine::emSquareSize() const
|
||||||
|
{
|
||||||
|
- return QFixed::QFixed(int(CTFontGetUnitsPerEm(ctfont)));
|
||||||
|
+ return QFixed(int(CTFontGetUnitsPerEm(ctfont)));
|
||||||
|
}
|
||||||
|
|
||||||
|
QFontEngine *QCoreTextFontEngine::cloneWithSize(qreal pixelSize) const
|
||||||
|
--
|
||||||
|
2.16.3
|
187
contrib/depends/patches/readline/readline-1.patch
Normal file
187
contrib/depends/patches/readline/readline-1.patch
Normal file
@ -0,0 +1,187 @@
|
|||||||
|
From c0572cecbeadc8fe24c70c5c39d49210a39ac719 Mon Sep 17 00:00:00 2001
|
||||||
|
From: Timothy Gu <timothygu99@gmail.com>
|
||||||
|
Date: Tue, 30 Sep 2014 10:32:33 -0700
|
||||||
|
Subject: [PATCH 1/2] signals: safeguard the remaining usage of frequently
|
||||||
|
missing signals
|
||||||
|
|
||||||
|
diff --git a/input.c b/input.c
|
||||||
|
index 117dfe8..465f0b9 100644
|
||||||
|
--- a/input.c
|
||||||
|
+++ b/input.c
|
||||||
|
@@ -532,9 +532,17 @@ rl_getc (stream)
|
||||||
|
Otherwise (not EINTR), some error occurred, also signifying EOF. */
|
||||||
|
if (errno != EINTR)
|
||||||
|
return (RL_ISSTATE (RL_STATE_READCMD) ? READERR : EOF);
|
||||||
|
- else if (_rl_caught_signal == SIGHUP || _rl_caught_signal == SIGTERM)
|
||||||
|
+ else if (_rl_caught_signal == SIGTERM
|
||||||
|
+#if defined(SIGHUP)
|
||||||
|
+ || _rl_caught_signal == SIGHUP
|
||||||
|
+#endif
|
||||||
|
+ )
|
||||||
|
return (RL_ISSTATE (RL_STATE_READCMD) ? READERR : EOF);
|
||||||
|
- else if (_rl_caught_signal == SIGINT || _rl_caught_signal == SIGQUIT)
|
||||||
|
+ else if (_rl_caught_signal == SIGINT
|
||||||
|
+#if defined(SIGQUIT)
|
||||||
|
+ || _rl_caught_signal == SIGQUIT
|
||||||
|
+#endif
|
||||||
|
+ )
|
||||||
|
RL_CHECK_SIGNALS ();
|
||||||
|
|
||||||
|
if (rl_signal_event_hook)
|
||||||
|
diff --git a/signals.c b/signals.c
|
||||||
|
index 61f02f9..7c921d6 100644
|
||||||
|
--- a/signals.c
|
||||||
|
+++ b/signals.c
|
||||||
|
@@ -216,7 +216,9 @@ _rl_handle_signal (sig)
|
||||||
|
/* FALLTHROUGH */
|
||||||
|
|
||||||
|
case SIGTERM:
|
||||||
|
+#if defined (SIGHUP)
|
||||||
|
case SIGHUP:
|
||||||
|
+#endif
|
||||||
|
#if defined (SIGTSTP)
|
||||||
|
case SIGTSTP:
|
||||||
|
case SIGTTOU:
|
||||||
|
@@ -426,7 +428,9 @@ rl_set_signals ()
|
||||||
|
|
||||||
|
rl_maybe_set_sighandler (SIGINT, rl_signal_handler, &old_int);
|
||||||
|
rl_maybe_set_sighandler (SIGTERM, rl_signal_handler, &old_term);
|
||||||
|
+#if defined (SIGHUP)
|
||||||
|
rl_maybe_set_sighandler (SIGHUP, rl_signal_handler, &old_hup);
|
||||||
|
+#endif
|
||||||
|
#if defined (SIGQUIT)
|
||||||
|
rl_maybe_set_sighandler (SIGQUIT, rl_signal_handler, &old_quit);
|
||||||
|
#endif
|
||||||
|
@@ -491,7 +495,9 @@ rl_clear_signals ()
|
||||||
|
overhead */
|
||||||
|
rl_maybe_restore_sighandler (SIGINT, &old_int);
|
||||||
|
rl_maybe_restore_sighandler (SIGTERM, &old_term);
|
||||||
|
+#if defined (SIGHUP)
|
||||||
|
rl_maybe_restore_sighandler (SIGHUP, &old_hup);
|
||||||
|
+#endif
|
||||||
|
#if defined (SIGQUIT)
|
||||||
|
rl_maybe_restore_sighandler (SIGQUIT, &old_quit);
|
||||||
|
#endif
|
||||||
|
--
|
||||||
|
1.8.3.2
|
||||||
|
|
||||||
|
|
||||||
|
From 6896ffa4fc85bf0dfae58e69a860d2076c1d9fd2 Mon Sep 17 00:00:00 2001
|
||||||
|
From: Timothy Gu <timothygu99@gmail.com>
|
||||||
|
Date: Tue, 30 Sep 2014 17:16:32 -0700
|
||||||
|
Subject: [PATCH 2/2] Handle missing S_IS* macros more gracefully
|
||||||
|
|
||||||
|
diff --git a/colors.c b/colors.c
|
||||||
|
index 89d9035..ec19844 100644
|
||||||
|
--- a/colors.c
|
||||||
|
+++ b/colors.c
|
||||||
|
@@ -152,14 +152,22 @@ _rl_print_color_indicator (char *f)
|
||||||
|
{
|
||||||
|
colored_filetype = C_FILE;
|
||||||
|
|
||||||
|
+#if defined (S_ISUID)
|
||||||
|
if ((mode & S_ISUID) != 0 && is_colored (C_SETUID))
|
||||||
|
colored_filetype = C_SETUID;
|
||||||
|
- else if ((mode & S_ISGID) != 0 && is_colored (C_SETGID))
|
||||||
|
+ else
|
||||||
|
+#endif
|
||||||
|
+#if defined (S_ISGID)
|
||||||
|
+ if ((mode & S_ISGID) != 0 && is_colored (C_SETGID))
|
||||||
|
colored_filetype = C_SETGID;
|
||||||
|
- else if (is_colored (C_CAP) && 0) //f->has_capability)
|
||||||
|
+ else
|
||||||
|
+#endif
|
||||||
|
+ if (is_colored (C_CAP) && 0) //f->has_capability)
|
||||||
|
colored_filetype = C_CAP;
|
||||||
|
+#if defined(S_IXUGO)
|
||||||
|
else if ((mode & S_IXUGO) != 0 && is_colored (C_EXEC))
|
||||||
|
colored_filetype = C_EXEC;
|
||||||
|
+#endif
|
||||||
|
else if ((1 < astat.st_nlink) && is_colored (C_MULTIHARDLINK))
|
||||||
|
colored_filetype = C_MULTIHARDLINK;
|
||||||
|
}
|
||||||
|
@@ -173,8 +181,10 @@ _rl_print_color_indicator (char *f)
|
||||||
|
colored_filetype = C_STICKY_OTHER_WRITABLE;
|
||||||
|
else
|
||||||
|
#endif
|
||||||
|
+#if defined (S_IWOTH)
|
||||||
|
if ((mode & S_IWOTH) != 0 && is_colored (C_OTHER_WRITABLE))
|
||||||
|
colored_filetype = C_OTHER_WRITABLE;
|
||||||
|
+#endif
|
||||||
|
#if defined (S_ISVTX)
|
||||||
|
else if ((mode & S_ISVTX) != 0 && is_colored (C_STICKY))
|
||||||
|
colored_filetype = C_STICKY;
|
||||||
|
diff --git a/colors.h b/colors.h
|
||||||
|
index fc926e5..e62edd0 100644
|
||||||
|
--- a/colors.h
|
||||||
|
+++ b/colors.h
|
||||||
|
@@ -96,7 +96,7 @@ enum indicator_no
|
||||||
|
};
|
||||||
|
|
||||||
|
|
||||||
|
-#if !S_IXUGO
|
||||||
|
+#if !S_IXUGO && defined(S_IXUSR) && defined(S_IXGRP) && defined(S_IXOTH)
|
||||||
|
# define S_IXUGO (S_IXUSR | S_IXGRP | S_IXOTH)
|
||||||
|
#endif
|
||||||
|
|
||||||
|
diff --git a/posixstat.h b/posixstat.h
|
||||||
|
index 3eb7f29..854a2c9 100644
|
||||||
|
--- a/posixstat.h
|
||||||
|
+++ b/posixstat.h
|
||||||
|
@@ -78,30 +78,44 @@
|
||||||
|
|
||||||
|
#if defined (S_IFBLK) && !defined (S_ISBLK)
|
||||||
|
#define S_ISBLK(m) (((m)&S_IFMT) == S_IFBLK) /* block device */
|
||||||
|
+#elif !defined (S_IFBLK)
|
||||||
|
+#define S_ISBLK(m) 0
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#if defined (S_IFCHR) && !defined (S_ISCHR)
|
||||||
|
#define S_ISCHR(m) (((m)&S_IFMT) == S_IFCHR) /* character device */
|
||||||
|
+#elif !defined (S_IFCHR)
|
||||||
|
+#define S_ISCHR(m) 0
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#if defined (S_IFDIR) && !defined (S_ISDIR)
|
||||||
|
#define S_ISDIR(m) (((m)&S_IFMT) == S_IFDIR) /* directory */
|
||||||
|
+#elif !defined (S_IFDIR)
|
||||||
|
+#define S_ISDIR(m) 0
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#if defined (S_IFREG) && !defined (S_ISREG)
|
||||||
|
#define S_ISREG(m) (((m)&S_IFMT) == S_IFREG) /* file */
|
||||||
|
+#elif !defined (S_IFREG)
|
||||||
|
+#define S_ISREG(m) 0
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#if defined (S_IFIFO) && !defined (S_ISFIFO)
|
||||||
|
#define S_ISFIFO(m) (((m)&S_IFMT) == S_IFIFO) /* fifo - named pipe */
|
||||||
|
+#elif !defined (S_IFIFO)
|
||||||
|
+#define S_ISFIFO(m) 0
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#if defined (S_IFLNK) && !defined (S_ISLNK)
|
||||||
|
#define S_ISLNK(m) (((m)&S_IFMT) == S_IFLNK) /* symbolic link */
|
||||||
|
+#elif !defined (S_IFLNK)
|
||||||
|
+#define S_ISLNK(m) 0
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#if defined (S_IFSOCK) && !defined (S_ISSOCK)
|
||||||
|
#define S_ISSOCK(m) (((m)&S_IFMT) == S_IFSOCK) /* socket */
|
||||||
|
+#elif !defined (S_IFSOCK)
|
||||||
|
+#define S_ISSOCK(m) 0
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/*
|
||||||
|
@@ -137,6 +151,8 @@
|
||||||
|
/* These are non-standard, but are used in builtins.c$symbolic_umask() */
|
||||||
|
#define S_IRUGO (S_IRUSR | S_IRGRP | S_IROTH)
|
||||||
|
#define S_IWUGO (S_IWUSR | S_IWGRP | S_IWOTH)
|
||||||
|
+#if defined(S_IXUSR) && defined(S_IXGRP) && defined(S_IXOTH)
|
||||||
|
#define S_IXUGO (S_IXUSR | S_IXGRP | S_IXOTH)
|
||||||
|
+#endif
|
||||||
|
|
||||||
|
#endif /* _POSIXSTAT_H_ */
|
||||||
|
--
|
||||||
|
1.8.3.2
|
||||||
|
|
@ -0,0 +1,22 @@
|
|||||||
|
From 9114d3957725acd34aa8b8d011585812f3369411 Mon Sep 17 00:00:00 2001
|
||||||
|
From: Jeroen Ooms <jeroenooms@gmail.com>
|
||||||
|
Date: Tue, 20 Oct 2015 13:10:38 +0200
|
||||||
|
Subject: [PATCH] enable static libraries on mingw
|
||||||
|
|
||||||
|
---
|
||||||
|
configure.ac | 2 +-
|
||||||
|
1 file changed, 1 insertion(+), 1 deletion(-)
|
||||||
|
|
||||||
|
diff --git a/configure.ac b/configure.ac
|
||||||
|
index 393505b..e92131a 100644
|
||||||
|
--- a/configure.ac
|
||||||
|
+++ b/configure.ac
|
||||||
|
@@ -265,7 +265,7 @@ case "${host_os}" in
|
||||||
|
libzmq_dso_visibility="no"
|
||||||
|
|
||||||
|
if test "x$enable_static" = "xyes"; then
|
||||||
|
- AC_MSG_ERROR([Building static libraries is not supported under MinGW32])
|
||||||
|
+ CPPFLAGS="-DZMQ_STATIC"
|
||||||
|
fi
|
||||||
|
|
||||||
|
# Set FD_SETSIZE to 1024
|
@ -0,0 +1,22 @@
|
|||||||
|
From 9e6745c12e0b100cd38acecc16ce7db02905e27c Mon Sep 17 00:00:00 2001
|
||||||
|
From: David Millard <dmillard10@gmail.com>
|
||||||
|
Date: Tue, 10 May 2016 13:53:53 -0700
|
||||||
|
Subject: [PATCH] Fix autotools for static MinGW builds
|
||||||
|
|
||||||
|
---
|
||||||
|
configure.ac | 2 +-
|
||||||
|
1 file changed, 1 insertion(+), 1 deletion(-)
|
||||||
|
|
||||||
|
diff --git a/configure.ac b/configure.ac
|
||||||
|
index 5a0fa14..def6ea7 100644
|
||||||
|
--- a/configure.ac
|
||||||
|
+++ b/configure.ac
|
||||||
|
@@ -259,7 +259,7 @@ case "${host_os}" in
|
||||||
|
libzmq_dso_visibility="no"
|
||||||
|
|
||||||
|
if test "x$enable_static" = "xyes"; then
|
||||||
|
- CPPFLAGS="-DZMQ_STATIC"
|
||||||
|
+ CPPFLAGS="-DZMQ_STATIC $CPPFLAGS"
|
||||||
|
fi
|
||||||
|
|
||||||
|
# Set FD_SETSIZE to 1024
|
29
contrib/depends/protobuf.mk
Normal file
29
contrib/depends/protobuf.mk
Normal file
@ -0,0 +1,29 @@
|
|||||||
|
package=protobuf
|
||||||
|
$(package)_version=$(native_$(package)_version)
|
||||||
|
$(package)_download_path=$(native_$(package)_download_path)
|
||||||
|
$(package)_file_name=$(native_$(package)_file_name)
|
||||||
|
$(package)_sha256_hash=$(native_$(package)_sha256_hash)
|
||||||
|
$(package)_dependencies=native_$(package)
|
||||||
|
$(package)_cxxflags=-std=c++11
|
||||||
|
|
||||||
|
define $(package)_set_vars
|
||||||
|
$(package)_config_opts=--disable-shared --with-protoc=$(build_prefix)/bin/protoc
|
||||||
|
$(package)_config_opts_linux=--with-pic
|
||||||
|
endef
|
||||||
|
|
||||||
|
define $(package)_config_cmds
|
||||||
|
$($(package)_autoconf)
|
||||||
|
endef
|
||||||
|
|
||||||
|
define $(package)_build_cmds
|
||||||
|
$(MAKE) -C src libprotobuf.la
|
||||||
|
endef
|
||||||
|
|
||||||
|
define $(package)_stage_cmds
|
||||||
|
$(MAKE) DESTDIR=$($(package)_staging_dir) -C src install-libLTLIBRARIES install-nobase_includeHEADERS &&\
|
||||||
|
$(MAKE) DESTDIR=$($(package)_staging_dir) install-pkgconfigDATA
|
||||||
|
endef
|
||||||
|
|
||||||
|
define $(package)_postprocess_cmds
|
||||||
|
rm lib/libprotoc.a
|
||||||
|
endef
|
82
contrib/depends/toolchain.cmake.in
Normal file
82
contrib/depends/toolchain.cmake.in
Normal file
@ -0,0 +1,82 @@
|
|||||||
|
# Set the system name, either Darwin, Linux, or Windows
|
||||||
|
SET(CMAKE_SYSTEM_NAME @depends@)
|
||||||
|
SET(CMAKE_BUILD_TYPE release)
|
||||||
|
|
||||||
|
SET(STATIC true)
|
||||||
|
SET(UNBOUND_STATIC true)
|
||||||
|
|
||||||
|
# where is the target environment
|
||||||
|
SET(CMAKE_FIND_ROOT_PATH @prefix@ /usr)
|
||||||
|
|
||||||
|
SET(ENV{PKG_CONFIG_PATH} @prefix@/lib/pkgconfig)
|
||||||
|
|
||||||
|
SET(LRELEASE_PATH @prefix@/native/bin CACHE FILEPATH "path to lrelease" FORCE)
|
||||||
|
|
||||||
|
SET(Readline_ROOT_DIR @prefix@)
|
||||||
|
|
||||||
|
SET(LIBUNWIND_INCLUDE_DIR @prefix@/include)
|
||||||
|
SET(LIBUNWIND_LIBRARIES @prefix@/lib/libunwind.a)
|
||||||
|
SET(LIBUNWIND_LIBRARY_DIRS @prefix@/lib)
|
||||||
|
|
||||||
|
SET(ZMQ_INCLUDE_PATH @prefix@/include)
|
||||||
|
SET(ZMQ_LIB @prefix@/lib/libzmq.a)
|
||||||
|
|
||||||
|
SET(BOOST_IGNORE_SYSTEM_PATHS_DEFAULT ON)
|
||||||
|
SET(BOOST_IGNORE_SYSTEM_PATH ON)
|
||||||
|
SET(BOOST_ROOT @prefix@)
|
||||||
|
SET(BOOST_LIBRARYDIR @prefix@/lib)
|
||||||
|
SET(BOOST_IGNORE_SYSTEM_PATHS_DEFAULT OFF)
|
||||||
|
SET(Boost_NO_SYSTEM_PATHS TRUE)
|
||||||
|
SET(Boost_USE_STATIC_LIBS TRUE)
|
||||||
|
SET(Boost_USE_STATIC_RUNTIME TRUE)
|
||||||
|
|
||||||
|
SET(OpenSSL_DIR @prefix@/lib)
|
||||||
|
SET(ARCHITECTURE @arch@)
|
||||||
|
|
||||||
|
# for libraries and headers in the target directories
|
||||||
|
set (CMAKE_FIND_ROOT_PATH_MODE_PROGRAM NEVER) # Find programs on host
|
||||||
|
set (CMAKE_FIND_ROOT_PATH_MODE_LIBRARY ONLY) # Find libs in target
|
||||||
|
set (CMAKE_FIND_ROOT_PATH_MODE_INCLUDE ONLY) # Find includes in target
|
||||||
|
|
||||||
|
# specify the cross compiler to be used. Darwin uses clang provided by the SDK.
|
||||||
|
if(CMAKE_SYSTEM_NAME STREQUAL "Darwin")
|
||||||
|
SET(CMAKE_C_COMPILER @prefix@/native/bin/clang)
|
||||||
|
SET(CMAKE_C_COMPILER_TARGET x86_64-apple-darwin11)
|
||||||
|
SET(CMAKE_CXX_COMPILER @prefix@/native/bin/clang++ -stdlib=libc++)
|
||||||
|
SET(CMAKE_CXX_COMPILER_TARGET x86_64-apple-darwin11)
|
||||||
|
SET(_CMAKE_TOOLCHAIN_PREFIX x86_64-apple-darwin11-)
|
||||||
|
SET(APPLE True)
|
||||||
|
SET(BUILD_TAG "mac-x64")
|
||||||
|
SET(BUILD_64 ON)
|
||||||
|
SET(ARCH "x86_64")
|
||||||
|
SET(BREW OFF)
|
||||||
|
SET(PORT OFF)
|
||||||
|
SET(CMAKE_OSX_SYSROOT "@sdk@/MacOSX10.11.sdk/")
|
||||||
|
SET(CMAKE_OSX_DEPLOYMENT_TARGET "10.08")
|
||||||
|
SET(CMAKE_CXX_STANDARD 11)
|
||||||
|
SET(CMAKE_OSX_ARCHITECTURES "x86_64")
|
||||||
|
SET(LLVM_ENABLE_PIC OFF)
|
||||||
|
SET(LLVM_ENABLE_PIE OFF)
|
||||||
|
else()
|
||||||
|
SET(CMAKE_C_COMPILER @CC@)
|
||||||
|
SET(CMAKE_CXX_COMPILER @CXX@)
|
||||||
|
endif()
|
||||||
|
|
||||||
|
if(ARCHITECTURE STREQUAL "arm")
|
||||||
|
set(ARCH "armv7-a")
|
||||||
|
set(ARM ON)
|
||||||
|
set(ARM_ID "armv7-a")
|
||||||
|
set(BUILD_64 OFF)
|
||||||
|
set(CMAKE_BUILD_TYPE release)
|
||||||
|
set(BUILD_TAG "linux-armv7")
|
||||||
|
set(ARM7)
|
||||||
|
elseif(ARCHITECTURE STREQUAL "aarch64")
|
||||||
|
set(ARCH "armv8-a")
|
||||||
|
set(ARM ON)
|
||||||
|
set(ARM_ID "armv8-a")
|
||||||
|
set(BUILD_TAG "linux-armv8")
|
||||||
|
set(BUILD_64 ON)
|
||||||
|
endif()
|
||||||
|
|
||||||
|
#Create a new global cmake flag that indicates building with depends
|
||||||
|
set (DEPENDS true)
|
@ -24,7 +24,7 @@
|
|||||||
// SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
// SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
||||||
//
|
//
|
||||||
#ifdef _WIN32
|
#ifdef _WIN32
|
||||||
#include <Winsock2.h>
|
#include <winsock2.h>
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#ifdef WIN32
|
#ifdef WIN32
|
||||||
|
2
external/CMakeLists.txt
vendored
2
external/CMakeLists.txt
vendored
@ -38,9 +38,7 @@
|
|||||||
find_package(Miniupnpc REQUIRED)
|
find_package(Miniupnpc REQUIRED)
|
||||||
|
|
||||||
message(STATUS "Using in-tree miniupnpc")
|
message(STATUS "Using in-tree miniupnpc")
|
||||||
|
|
||||||
add_subdirectory(miniupnp/miniupnpc)
|
add_subdirectory(miniupnp/miniupnpc)
|
||||||
|
|
||||||
set_property(TARGET libminiupnpc-static PROPERTY FOLDER "external")
|
set_property(TARGET libminiupnpc-static PROPERTY FOLDER "external")
|
||||||
if(MSVC)
|
if(MSVC)
|
||||||
set_property(TARGET libminiupnpc-static APPEND_STRING PROPERTY COMPILE_FLAGS " -wd4244 -wd4267")
|
set_property(TARGET libminiupnpc-static APPEND_STRING PROPERTY COMPILE_FLAGS " -wd4244 -wd4267")
|
||||||
|
@ -28,7 +28,9 @@
|
|||||||
|
|
||||||
set(blocksdat "")
|
set(blocksdat "")
|
||||||
if(PER_BLOCK_CHECKPOINT)
|
if(PER_BLOCK_CHECKPOINT)
|
||||||
if(APPLE)
|
if(APPLE AND DEPENDS)
|
||||||
|
add_custom_command(OUTPUT blocksdat.o MAIN_DEPENDENCY ../blocks/checkpoints.dat COMMAND cd ${CMAKE_CURRENT_SOURCE_DIR} && touch stub.c && ${CMAKE_C_COMPILER} --target=x86_64-apple-darwin11 -o stub.o -c stub.c COMMAND cd ${CMAKE_CURRENT_SOURCE_DIR} && ${CMAKE_LINKER} -r -sectcreate __DATA __blocks_dat ../blocks/checkpoints.dat -o ${CMAKE_CURRENT_BINARY_DIR}/blocksdat.o stub.o && rm -f stub.*)
|
||||||
|
elseif(APPLE AND NOT DEPENDS)
|
||||||
add_custom_command(OUTPUT blocksdat.o MAIN_DEPENDENCY ../blocks/checkpoints.dat COMMAND cd ${CMAKE_CURRENT_SOURCE_DIR} && touch stub.c && ${CMAKE_C_COMPILER} -o stub.o -c stub.c COMMAND cd ${CMAKE_CURRENT_SOURCE_DIR} && ${CMAKE_LINKER} ${LD_RAW_FLAGS} -r -sectcreate __DATA __blocks_dat ../blocks/checkpoints.dat -o ${CMAKE_CURRENT_BINARY_DIR}/blocksdat.o stub.o && rm -f stub.*)
|
add_custom_command(OUTPUT blocksdat.o MAIN_DEPENDENCY ../blocks/checkpoints.dat COMMAND cd ${CMAKE_CURRENT_SOURCE_DIR} && touch stub.c && ${CMAKE_C_COMPILER} -o stub.o -c stub.c COMMAND cd ${CMAKE_CURRENT_SOURCE_DIR} && ${CMAKE_LINKER} ${LD_RAW_FLAGS} -r -sectcreate __DATA __blocks_dat ../blocks/checkpoints.dat -o ${CMAKE_CURRENT_BINARY_DIR}/blocksdat.o stub.o && rm -f stub.*)
|
||||||
else()
|
else()
|
||||||
add_custom_command(OUTPUT blocksdat.o MAIN_DEPENDENCY ../blocks/checkpoints.dat COMMAND cd ${CMAKE_CURRENT_SOURCE_DIR} && cp ../blocks/checkpoints.dat blocks.dat && ${CMAKE_LINKER} ${LD_RAW_FLAGS} -r -b binary -o ${CMAKE_CURRENT_BINARY_DIR}/blocksdat.o blocks.dat && rm -f blocks.dat)
|
add_custom_command(OUTPUT blocksdat.o MAIN_DEPENDENCY ../blocks/checkpoints.dat COMMAND cd ${CMAKE_CURRENT_SOURCE_DIR} && cp ../blocks/checkpoints.dat blocks.dat && ${CMAKE_LINKER} ${LD_RAW_FLAGS} -r -b binary -o ${CMAKE_CURRENT_BINARY_DIR}/blocksdat.o blocks.dat && rm -f blocks.dat)
|
||||||
|
@ -27,10 +27,14 @@
|
|||||||
# THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
# THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
||||||
|
|
||||||
if(APPLE)
|
if(APPLE)
|
||||||
|
if(DEPENDS)
|
||||||
|
list(APPEND EXTRA_LIBRARIES "-framework Foundation -framework ApplicationServices -framework AppKit -framework IOKit")
|
||||||
|
else()
|
||||||
find_library(IOKIT_LIBRARY IOKit)
|
find_library(IOKIT_LIBRARY IOKit)
|
||||||
mark_as_advanced(IOKIT_LIBRARY)
|
mark_as_advanced(IOKIT_LIBRARY)
|
||||||
list(APPEND EXTRA_LIBRARIES ${IOKIT_LIBRARY})
|
list(APPEND EXTRA_LIBRARIES ${IOKIT_LIBRARY})
|
||||||
endif()
|
endif()
|
||||||
|
endif()
|
||||||
|
|
||||||
set(checkpoints_sources
|
set(checkpoints_sources
|
||||||
checkpoints.cpp)
|
checkpoints.cpp)
|
||||||
|
@ -27,10 +27,14 @@
|
|||||||
# THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
# THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
||||||
|
|
||||||
if(APPLE)
|
if(APPLE)
|
||||||
|
if(DEPENDS)
|
||||||
|
list(APPEND EXTRA_LIBRARIES "-framework Foundation -framework ApplicationServices -framework AppKit -framework IOKit")
|
||||||
|
else()
|
||||||
find_library(IOKIT_LIBRARY IOKit)
|
find_library(IOKIT_LIBRARY IOKit)
|
||||||
mark_as_advanced(IOKIT_LIBRARY)
|
mark_as_advanced(IOKIT_LIBRARY)
|
||||||
list(APPEND EXTRA_LIBRARIES ${IOKIT_LIBRARY})
|
list(APPEND EXTRA_LIBRARIES ${IOKIT_LIBRARY})
|
||||||
endif()
|
endif()
|
||||||
|
endif()
|
||||||
|
|
||||||
set(cryptonote_basic_sources
|
set(cryptonote_basic_sources
|
||||||
account.cpp
|
account.cpp
|
||||||
|
@ -28,7 +28,9 @@
|
|||||||
|
|
||||||
set(blocksdat "")
|
set(blocksdat "")
|
||||||
if(PER_BLOCK_CHECKPOINT)
|
if(PER_BLOCK_CHECKPOINT)
|
||||||
if(APPLE)
|
if(APPLE AND DEPENDS)
|
||||||
|
add_custom_command(OUTPUT blocksdat.o MAIN_DEPENDENCY ../blocks/checkpoints.dat COMMAND cd ${CMAKE_CURRENT_SOURCE_DIR} && touch stub.c && ${CMAKE_C_COMPILER} --target=x86_64-apple-darwin11 -o stub.o -c stub.c COMMAND cd ${CMAKE_CURRENT_SOURCE_DIR} && ${CMAKE_LINKER} -r -sectcreate __DATA __blocks_dat ../blocks/checkpoints.dat -o ${CMAKE_CURRENT_BINARY_DIR}/blocksdat.o stub.o && rm -f stub.*)
|
||||||
|
elseif(APPLE AND NOT DEPENDS)
|
||||||
add_custom_command(OUTPUT blocksdat.o MAIN_DEPENDENCY ../blocks/checkpoints.dat COMMAND cd ${CMAKE_CURRENT_SOURCE_DIR} && touch stub.c && ${CMAKE_C_COMPILER} -o stub.o -c stub.c COMMAND cd ${CMAKE_CURRENT_SOURCE_DIR} && ${CMAKE_LINKER} ${LD_RAW_FLAGS} -r -sectcreate __DATA __blocks_dat ../blocks/checkpoints.dat -o ${CMAKE_CURRENT_BINARY_DIR}/blocksdat.o stub.o && rm -f stub.*)
|
add_custom_command(OUTPUT blocksdat.o MAIN_DEPENDENCY ../blocks/checkpoints.dat COMMAND cd ${CMAKE_CURRENT_SOURCE_DIR} && touch stub.c && ${CMAKE_C_COMPILER} -o stub.o -c stub.c COMMAND cd ${CMAKE_CURRENT_SOURCE_DIR} && ${CMAKE_LINKER} ${LD_RAW_FLAGS} -r -sectcreate __DATA __blocks_dat ../blocks/checkpoints.dat -o ${CMAKE_CURRENT_BINARY_DIR}/blocksdat.o stub.o && rm -f stub.*)
|
||||||
else()
|
else()
|
||||||
add_custom_command(OUTPUT blocksdat.o MAIN_DEPENDENCY ../blocks/checkpoints.dat COMMAND cd ${CMAKE_CURRENT_SOURCE_DIR} && cp ../blocks/checkpoints.dat blocks.dat && ${CMAKE_LINKER} ${LD_RAW_FLAGS} -r -b binary -o ${CMAKE_CURRENT_BINARY_DIR}/blocksdat.o blocks.dat && rm -f blocks.dat)
|
add_custom_command(OUTPUT blocksdat.o MAIN_DEPENDENCY ../blocks/checkpoints.dat COMMAND cd ${CMAKE_CURRENT_SOURCE_DIR} && cp ../blocks/checkpoints.dat blocks.dat && ${CMAKE_LINKER} ${LD_RAW_FLAGS} -r -b binary -o ${CMAKE_CURRENT_BINARY_DIR}/blocksdat.o blocks.dat && rm -f blocks.dat)
|
||||||
|
@ -42,7 +42,12 @@ IF(NOT CMAKE_CROSSCOMPILING)
|
|||||||
add_executable(generate_translations_header generate_translations_header.c)
|
add_executable(generate_translations_header generate_translations_header.c)
|
||||||
ENDIF(NOT CMAKE_CROSSCOMPILING)
|
ENDIF(NOT CMAKE_CROSSCOMPILING)
|
||||||
|
|
||||||
|
if(LRELEASE_PATH STREQUAL "")
|
||||||
find_program(LRELEASE lrelease)
|
find_program(LRELEASE lrelease)
|
||||||
|
else()
|
||||||
|
set(LRELEASE ${LRELEASE_PATH}/lrelease)
|
||||||
|
endif()
|
||||||
|
|
||||||
if(LRELEASE STREQUAL "LRELEASE-NOTFOUND")
|
if(LRELEASE STREQUAL "LRELEASE-NOTFOUND")
|
||||||
set(ts_files "")
|
set(ts_files "")
|
||||||
message(WARNING "lrelease program not found, translation files not built")
|
message(WARNING "lrelease program not found, translation files not built")
|
||||||
@ -68,7 +73,7 @@ string(REPLACE ".ts" ".qm" qm_files "${ts_files}")
|
|||||||
|
|
||||||
add_custom_command(TARGET generate_translations_header
|
add_custom_command(TARGET generate_translations_header
|
||||||
POST_BUILD
|
POST_BUILD
|
||||||
COMMAND generate_translations_header ${qm_files}
|
COMMAND ./generate_translations_header ${qm_files}
|
||||||
WORKING_DIRECTORY "${CMAKE_CURRENT_BIN_DIR}"
|
WORKING_DIRECTORY "${CMAKE_CURRENT_BIN_DIR}"
|
||||||
COMMENT "Generating embedded translations header")
|
COMMENT "Generating embedded translations header")
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user