From mboxrd@z Thu Jan 1 00:00:00 1970 From: Yegor Yefremov Date: Thu, 13 Oct 2011 12:39:12 +0200 Subject: [Buildroot] [PATCH v2] boost: New package added. Version 1.47 Message-ID: <4E96BFD0.2050706@visionsystems.de> List-Id: MIME-Version: 1.0 Content-Type: text/plain; charset="us-ascii" Content-Transfer-Encoding: 7bit To: buildroot@busybox.net Signed-off-by: Allan W. Nielsen Signed-off-by: Yegor Yefremov --- changes: 1. convert GENTARGETS to the latest syntax 2. add all dependencies in one line package/Config.in | 1 package/boost/Config.in | 99 ++++++++++++++++++++++++++++++++++++++++++++++++ package/boost/boost.mk | 83 ++++++++++++++++++++++++++++++++++++++++ 3 files changed, 183 insertions(+) create mode 100644 package/boost/Config.in create mode 100644 package/boost/boost.mk Index: b/package/Config.in =================================================================== --- a/package/Config.in +++ b/package/Config.in @@ -346,6 +346,7 @@ source "package/fftw/Config.in" source "package/libargtable2/Config.in" source "package/argp-standalone/Config.in" +source "package/boost/Config.in" source "package/libatomic_ops/Config.in" source "package/libcap/Config.in" source "package/libdaemon/Config.in" Index: b/package/boost/Config.in =================================================================== --- /dev/null +++ b/package/boost/Config.in @@ -0,0 +1,99 @@ +config BR2_PACKAGE_BOOST + bool "boost" + select BR2_PACKAGE_BZIP2 + select BR2_PACKAGE_ZLIB + help + A general purpose c++ library + + http://www.boost.org/ + +menu "Boost libraries" + depends on BR2_PACKAGE_BOOST + +config BR2_PACKAGE_BOOST_MULTITHREADED + depends on BR2_PACKAGE_BOOST + bool "boost-multithreaded" + help + Build the boost libraries as multithreaded + +config BR2_PACKAGE_BOOST_CHRONO + depends on BR2_PACKAGE_BOOST + bool "boost-chrono" + +config BR2_PACKAGE_BOOST_DATE_TIME + depends on BR2_PACKAGE_BOOST + bool "boost-date_time" + +config BR2_PACKAGE_BOOST_EXCEPTION + depends on BR2_PACKAGE_BOOST + bool "boost-exception" + +config BR2_PACKAGE_BOOST_FILESYSTEM + depends on BR2_PACKAGE_BOOST + bool "boost-filesystem" + +config BR2_PACKAGE_BOOST_GRAPH + depends on BR2_PACKAGE_BOOST + bool "boost-graph" + +config BR2_PACKAGE_BOOST_GRAPH_PARALLEL + depends on BR2_PACKAGE_BOOST + bool "boost-graph_parallel" + +config BR2_PACKAGE_BOOST_ICU + depends on BR2_PACKAGE_BOOST + bool "boost-icu" + select BR2_PACKAGE_ICU + +config BR2_PACKAGE_BOOST_IOSTREAMS + depends on BR2_PACKAGE_BOOST + bool "boost-iostreams" + +config BR2_PACKAGE_BOOST_MATH + depends on BR2_PACKAGE_BOOST + bool "boost-math" + +config BR2_PACKAGE_BOOST_MPI + depends on BR2_PACKAGE_BOOST + bool "boost-mpi" + +config BR2_PACKAGE_BOOST_PROGRAM_OPTIONS + depends on BR2_PACKAGE_BOOST + bool "boost-program_options" + +config BR2_PACKAGE_BOOST_RANDOM + depends on BR2_PACKAGE_BOOST + bool "boost-random" + +config BR2_PACKAGE_BOOST_REGEX + depends on BR2_PACKAGE_BOOST + bool "boost-regex" + +config BR2_PACKAGE_BOOST_SERIALIZATION + depends on BR2_PACKAGE_BOOST + bool "boost-serialization" + +config BR2_PACKAGE_BOOST_SIGNALS + depends on BR2_PACKAGE_BOOST + bool "boost-signals" + +config BR2_PACKAGE_BOOST_SYSTEM + depends on BR2_PACKAGE_BOOST + bool "boost-system" + +config BR2_PACKAGE_BOOST_TEST + depends on BR2_PACKAGE_BOOST + bool "boost-test" + +config BR2_PACKAGE_BOOST_THREAD + depends on BR2_PACKAGE_BOOST + bool "boost-thread" + +config BR2_PACKAGE_BOOST_WAVE + depends on BR2_PACKAGE_BOOST + bool "boost-wave" + + +endmenu + + Index: b/package/boost/boost.mk =================================================================== --- /dev/null +++ b/package/boost/boost.mk @@ -0,0 +1,83 @@ +############################################################# +# +# Boost +# +############################################################# + +BOOST_VERSION = 1.47.0 +BOOST_FILE_VERSION = $(subst .,_,$(BOOST_VERSION)) +BOOST_SOURCE = boost_$(BOOST_FILE_VERSION).tar.bz2 +BOOST_SITE = http://$(BR2_SOURCEFORGE_MIRROR).dl.sourceforge.net/sourceforge/boost +BOOST_INSTALL_STAGING = YES + +TARGET_CC_VERSION = $(shell $(TARGET_CC) --version | head -n 1 | sed -e "s/.*[[:space:]]\([[:digit:].]\+$$\)/\1/g" ) + +BOOST_DEPENDENCIES = bzip2 zlib + +BOOST_FLAGS = +BOOST_WITHOUT_FLAGS = python + +BOOST_WITHOUT_FLAGS += $(if $(BR2_PACKAGE_BOOST_CHRONO),,chrono) +BOOST_WITHOUT_FLAGS += $(if $(BR2_PACKAGE_BOOST_DATE_TIME),,date_time) +BOOST_WITHOUT_FLAGS += $(if $(BR2_PACKAGE_BOOST_EXCEPTION),,exception) +BOOST_WITHOUT_FLAGS += $(if $(BR2_PACKAGE_BOOST_FILESYSTEM),,filesystem) +BOOST_WITHOUT_FLAGS += $(if $(BR2_PACKAGE_BOOST_GRAPH),,graph) +BOOST_WITHOUT_FLAGS += $(if $(BR2_PACKAGE_BOOST_GRAPH_PARALLEL),,graph_parallel) +BOOST_WITHOUT_FLAGS += $(if $(BR2_PACKAGE_BOOST_IOSTREAMS),,iostreams) +BOOST_WITHOUT_FLAGS += $(if $(BR2_PACKAGE_BOOST_MATH),,math) +BOOST_WITHOUT_FLAGS += $(if $(BR2_PACKAGE_BOOST_MPI),,mpi) +BOOST_WITHOUT_FLAGS += $(if $(BR2_PACKAGE_BOOST_PROGRAM_OPTIONS),,program_options) +BOOST_WITHOUT_FLAGS += $(if $(BR2_PACKAGE_BOOST_RANDOM),,random) +BOOST_WITHOUT_FLAGS += $(if $(BR2_PACKAGE_BOOST_REGEX),,regex) +BOOST_WITHOUT_FLAGS += $(if $(BR2_PACKAGE_BOOST_SERIALIZATION),,serialization) +BOOST_WITHOUT_FLAGS += $(if $(BR2_PACKAGE_BOOST_SIGNALS),,signals) +BOOST_WITHOUT_FLAGS += $(if $(BR2_PACKAGE_BOOST_SYSTEM),,system) +BOOST_WITHOUT_FLAGS += $(if $(BR2_PACKAGE_BOOST_TEST),,test) +BOOST_WITHOUT_FLAGS += $(if $(BR2_PACKAGE_BOOST_THREAD),,thread) +BOOST_WITHOUT_FLAGS += $(if $(BR2_PACKAGE_BOOST_WAVE),,wave) + +ifeq ($(BR2_PACKAGE_BOOST_ICU),y) +BOOST_FLAGS += --with-icu +BOOST_DEPENDENCIES += icu +else +BOOST_FLAGS += --without-icu +endif + +BOOST_LINK = $(if $(BR2_PREFER_STATIC_LIB),static,shared) +BOOST_MULTI = $(if $(BR2_PACKAGE_BOOST_MULTITHREADED),multi,single) +BOOST_VARIANT = $(if $(BR2_ENABLE_DEBUG),debug,release) + +BOOST_WITHOUT_FLAGS_COMMASEPERATED += $(subst $(space),$(comma),$(strip $(BOOST_WITHOUT_FLAGS))) +BOOST_FLAGS += $(if $(BOOST_WITHOUT_FLAGS_COMMASEPERATED), --without-libraries=$(BOOST_WITHOUT_FLAGS_COMMASEPERATED)) + +define BOOST_CONFIGURE_CMDS + (cd $(@D) && ./bootstrap.sh $(BOOST_FLAGS)) + echo "using gcc : $(TARGET_CC_VERSION) : \"$(TARGET_CXX)\" : \"$(TARGET_CXXFLAGS)\" \"$(TARGET_LDFLAGS)\" ;" > $(@D)/user-config.jam + echo "" >> $(@D)/user-config.jam +endef + +define BOOST_INSTALL_TARGET_CMDS + (cd $(@D) && ./b2 -q -d+2 \ + --user-config=$(@D)/user-config.jam \ + toolset=gcc \ + variant=$(BOOST_VARIANT) \ + link=$(BOOST_LINK) \ + threading=$(BOOST_MULTI) \ + runtime-link=$(BOOST_LINK) \ + --prefix=$(TARGET_DIR)/usr \ + --layout=system install ) +endef + +define BOOST_INSTALL_STAGING_CMDS + (cd $(@D) && ./bjam -d+2 \ + --user-config=$(@D)/user-config.jam \ + toolset=gcc \ + variant=$(BOOST_VARIANT) \ + link=$(BOOST_LINK) \ + threading=$(BOOST_MULTI) \ + runtime-link=$(BOOST_LINK) \ + --prefix=$(STAGING_DIR)/usr \ + --layout=system install) +endef + +$(eval $(call GENTARGETS))