From d4f1b24ea9c56ad514c249b15f9449f6389856c5 Mon Sep 17 00:00:00 2001 From: Rosen Penev Date: Sun, 11 Aug 2019 21:46:29 -0700 Subject: [PATCH] fbthrift: Update to 2019-09-22 Signed-off-by: Rosen Penev (cherry-picked from 7139cddccf73a6e67a80e808c8f760dd3da9e1f8) --- libs/fbthrift/Makefile | 49 ++++++++++++++++----------- libs/fbthrift/patches/010-boost.patch | 14 ++++++++ 2 files changed, 43 insertions(+), 20 deletions(-) create mode 100644 libs/fbthrift/patches/010-boost.patch diff --git a/libs/fbthrift/Makefile b/libs/fbthrift/Makefile index 823436fd8e..d21b6dcd13 100644 --- a/libs/fbthrift/Makefile +++ b/libs/fbthrift/Makefile @@ -1,19 +1,22 @@ include $(TOPDIR)/rules.mk PKG_NAME:=fbthrift -PKG_VERSION:=2019.06.10.00 -PKG_RELEASE:=2 +PKG_SOURCE_DATE:=2019-09-22 +PKG_SOURCE_VERSION:=2f9839604e2569120cc4876c667388da6d7342f2 +PKG_RELEASE:=1 -PKG_SOURCE:=$(PKG_NAME)-$(PKG_VERSION).tar.gz -PKG_SOURCE_URL:=https://codeload.github.com/facebook/fbthrift/tar.gz/v$(PKG_VERSION)? -PKG_HASH:=0897c66564a2742b24dd6ae77812b42987c3493944d1d5d40d4005d71deb7cb5 +PKG_SOURCE:=$(PKG_NAME)-$(PKG_SOURCE_DATE).tar.gz +PKG_SOURCE_URL:=https://codeload.github.com/facebook/fbthrift/tar.gz/$(PKG_SOURCE_VERSION)? +PKG_HASH:=339a73610ad19070d33151127966aaf56e5df3640c238292fc74658c3075da3a +PKG_BUILD_DIR:=$(BUILD_DIR)/$(PKG_NAME)-$(PKG_SOURCE_VERSION) +HOST_BUILD_DIR:=$(BUILD_DIR_HOST)/$(PKG_NAME)-$(PKG_SOURCE_VERSION) PKG_MAINTAINER:=Amol Bhave PKG_LICENSE:=Apache-2.0 PKG_LICENSE_FILES:=LICENSE HOST_BUILD_DEPENDS:=libmstch/host -PKG_BUILD_DEPENDS:=fbthrift/host +PKG_BUILD_DEPENDS:=fbthrift/host libwangle librsocket-cpp HOST_BUILD_PARALLEL:=1 PKG_BUILD_PARALLEL:=1 @@ -24,34 +27,40 @@ include $(INCLUDE_DIR)/host-build.mk include $(INCLUDE_DIR)/cmake.mk define Package/fbthrift - SECTION:=libs - CATEGORY:=Libraries - TITLE:=Facebook's branch of Apache Thrift, including a new C++ server. - DEPENDS:=+libwangle +libfmt +librsocket-cpp + SECTION:=libs + CATEGORY:=Libraries + TITLE:=Facebook's branch of Apache Thrift, including a new C++ server. + URL:=https://github.com/facebook/fbthrift + DEPENDS:=+libfmt +libfolly endef define Package/fbthrift/description - Facebook's branch of Apache Thrift, including a new C++ server. + Facebook's branch of Apache Thrift, including a new C++ server. endef CMAKE_HOST_OPTIONS += \ - -DBoost_NO_BOOST_CMAKE=ON \ - -DCMAKE_SKIP_RPATH=FALSE \ + -DBUILD_SHARED_LIBS=ON \ + -DCMAKE_SKIP_RPATH=OFF \ -DCMAKE_INSTALL_RPATH="${STAGING_DIR_HOSTPKG}/lib" \ -Dcompiler_only=ON CMAKE_OPTIONS += \ - -DBoost_NO_BOOST_CMAKE=ON \ - -DBUILD_SHARED_LIBS=ON \ -DCMAKE_POSITION_INDEPENDENT_CODE=ON \ + -DCXX_STD=c++14 \ -Dlib_only=ON \ -DTHRIFT1="$(STAGING_DIR_HOSTPKG)/bin/thrift1" \ - -DTHRIFT_COMPILER_INCLUDE="$(STAGING_DIR_HOSTPKG)/include/" + -DTHRIFT_COMPILER_INCLUDE="$(STAGING_DIR_HOSTPKG)/include/" \ + -Dpython-six_DIR=OFF -define Package/fbthrift/install - $(INSTALL_DIR) $(1)/usr/lib - $(CP) $(PKG_INSTALL_DIR)/usr/lib/lib*.so* $(1)/usr/lib/ -endef +# This should not be necessary as it is supposed to be done above. +# Someone broke something. +HOST_LDFLAGS += -Wl,-rpath="$(STAGING_DIR_HOSTPKG)/lib" + +# GCC9 bug +TARGET_LDFLAGS += -fno-lto + +TARGET_CFLAGS += -ffunction-sections -fdata-sections +TARGET_LDFLAGS += -Wl,--gc-sections,--as-needed $(eval $(call BuildPackage,fbthrift)) $(eval $(call HostBuild)) diff --git a/libs/fbthrift/patches/010-boost.patch b/libs/fbthrift/patches/010-boost.patch new file mode 100644 index 0000000000..a393683451 --- /dev/null +++ b/libs/fbthrift/patches/010-boost.patch @@ -0,0 +1,14 @@ +--- a/CMakeLists.txt ++++ b/CMakeLists.txt +@@ -44,7 +44,11 @@ endif(MSVC) + find_package( + Boost 1.54.0 REQUIRED #1.54.0 or greater + COMPONENTS ++ context ++ date_time + filesystem ++ program_options ++ regex + system + thread + ) -- 2.30.2