X-Git-Url: http://git.openwrt.org/?p=openwrt%2Fsvn-archive%2Farchive.git;a=blobdiff_plain;f=libs%2Fboost%2FMakefile;h=1d6c2fbb897381a336aeb039510b5e09db828a05;hp=26886ba221cb028b9bc2197bc5e5030e3cabff54;hb=fa1bbd4c195bac7658dcbd737f80c3fe23125aeb;hpb=c79b85617e4bf9cbe275c88273db717d34688ad3 diff --git a/libs/boost/Makefile b/libs/boost/Makefile index 26886ba221..1d6c2fbb89 100644 --- a/libs/boost/Makefile +++ b/libs/boost/Makefile @@ -1,10 +1,9 @@ -# -# Copyright (C) 2006 OpenWrt.org +# +# Copyright (C) 2009-2010 OpenWrt.org # # This is free software, licensed under the GNU General Public License v2. # See /LICENSE for more information. # -# $Id: Makefile 12228 2009-03-12 22:43:15Z mirko $ # Dude, this "boost" is really one of the most crude stuff I ported yet. @@ -15,63 +14,264 @@ PKG_VERSION:=1_38_0 PKG_RELEASE:=1 PKG_SOURCE:=$(PKG_NAME)_$(PKG_VERSION).tar.gz -PKG_SOURCE_URL:=@SF/boost \ - +PKG_SOURCE_URL:=@SF/boost PKG_BUILD_DIR:=$(BUILD_DIR)/$(PKG_NAME)_$(PKG_VERSION) +PKG_MD5SUM:=a4fc691c4e7c49b3b9b54a667d8f5529 + +PKG_BUILD_DEPENDS:=boost-jam/host +PKG_BUILD_PARALLEL:=1 + +PKG_CONFIG_DEPENDS := \ + CONFIG_PACKAGE_boost-date_time \ + CONFIG_PACKAGE_boost-filesystem \ + CONFIG_PACKAGE_boost-graph \ + CONFIG_PACKAGE_boost-iostreams \ + CONFIG_PACKAGE_boost-math \ + CONFIG_PACKAGE_boost-program_options \ + CONFIG_PACKAGE_boost-python \ + CONFIG_PACKAGE_boost-regex \ + CONFIG_PACKAGE_boost-serialization \ + CONFIG_PACKAGE_boost-signals \ + CONFIG_PACKAGE_boost-system \ + CONFIG_PACKAGE_boost-test \ + CONFIG_PACKAGE_boost-thread \ + CONFIG_PACKAGE_boost-wave \ include $(INCLUDE_DIR)/package.mk -define Package/boost +define Package/boost/Default SECTION:=libs CATEGORY:=Libraries - TITLE:=Boost provides free peer-reviewed portable C++ source libraries - URL:=http://www.boost.org/ - DEPENDS:=+boost-jam + TITLE:=Boost C++ source libraries + URL:=http://www.boost.org + DEPENDS:=+libstdcpp @!LINUX_2_4 endef -define Build/Configure +define Package/boost/Default/description + Boost provides free peer-reviewed portable C++ source libraries endef -# bjam does not support anything like DESTDIR -CONFIGURE_PREFIX:=$(PKG_INSTALL_DIR) +define Package/boost-date_time + $(call Package/boost/Default) + TITLE+= (date_time) +endef + +define Package/boost-filesystem + $(call Package/boost/Default) + TITLE+= (filesystem) +endef + +define Package/boost-function_types + $(call Package/boost/Default) + TITLE+= (function_types) + BUILD_ONLY:=1 +endef + +define Package/boost-graph + $(call Package/boost/Default) + TITLE+= (graph) +endef + +define Package/boost-iostreams + $(call Package/boost/Default) + TITLE+= (iostreams) + DEPENDS+= +zlib +endef + +define Package/boost-math + $(call Package/boost/Default) + TITLE+= (math) +endef + +#define Package/boost-mpi +# $(call Package/boost/Default) +# TITLE+= (mpi) +#endef + +define Package/boost-program_options + $(call Package/boost/Default) + TITLE+= (program_options) +endef + +define Package/boost-python + $(call Package/boost/Default) + TITLE+= (python) + DEPENDS+= +python +endef + +define Package/boost-regex + $(call Package/boost/Default) + TITLE+= (regex) +endef + +define Package/boost-serialization + $(call Package/boost/Default) + TITLE+= (serialization) +endef + +define Package/boost-signals + $(call Package/boost/Default) + TITLE+= (signals) +endef + +define Package/boost-system + $(call Package/boost/Default) + TITLE+= (system) +endef + +define Package/boost-test + $(call Package/boost/Default) + TITLE+= (test) +endef + +define Package/boost-thread + $(call Package/boost/Default) + TITLE+= (thread) +endef -LIBRARIES:= \ - serialization \ +define Package/boost-wave + $(call Package/boost/Default) + TITLE+= (wave) +endef +define Package/boost + $(call Package/boost/Default) + TITLE+= (header-only) + BUILDONLY:=1 +endef + +define Build/Configure +endef + +CONFIGURE_PREFIX:=$(PKG_INSTALL_DIR) define Build/Compile - (cd $(PKG_BUILD_DIR) ; \ - echo "using gcc : : $(TOOLCHAIN_DIR)/usr/bin/$(GNU_TARGET_NAME)-gcc : $(CFLAGS) $(CXXFLAGS) $(LDFLAGS) ;" > tools/build/v2/site-config.jam ; \ - $(STAGING_DIR_HOST)/usr/bin/bjam \ + ( cd $(PKG_BUILD_DIR) ; \ + echo "using gcc : : $(GNU_TARGET_NAME)-gcc : $(TARGET_CFLAGS) $(TARGET_CXXFLAGS) $(TARGET_LDFLAGS) ;" > tools/build/v2/site-config.jam ; \ + $(if $(CONFIG_PACKAGE_boost-python), \ + echo "using python : : $(STAGING_DIR_ROOT)/usr/bin/python : $(STAGING_DIR)/usr/include/python2.6/ ;" >> \ + tools/build/v2/site-config.jam; \ + ) \ + bjam \ '-sBUILD=release space on off' \ - --toolset=gcc \ - $(foreach c, $(LIBRARIES), \ - --with-$(c) \ - ) \ + $(filter -j%,$(PKG_JOBS)) \ + --toolset=gcc --build-type=minimal --layout=system \ + --disable-long-double \ $(CONFIGURE_ARGS) \ + $(if $(CONFIG_PACKAGE_boost-date_time),--with-date_time) \ + $(if $(CONFIG_PACKAGE_boost-filesystem),--with-filesystem) \ + $(if $(CONFIG_PACKAGE_boost-function_types),--with-function_types) \ + $(if $(CONFIG_PACKAGE_boost-graph),--with-graph) \ + $(if $(CONFIG_PACKAGE_boost-iostreams),--with-iostreams) \ + $(if $(CONFIG_PACKAGE_boost-math),--with-math) \ + $(if $(CONFIG_PACKAGE_boost-mpi),--with-mpi) \ + $(if $(CONFIG_PACKAGE_boost-program_options),--with-program_options) \ + $(if $(CONFIG_PACKAGE_boost-python),--with-python) \ + $(if $(CONFIG_PACKAGE_boost-regex),--with-regex) \ + $(if $(CONFIG_PACKAGE_boost-serialization),--with-serialization) \ + $(if $(CONFIG_PACKAGE_boost-signals),--with-signals) \ + $(if $(CONFIG_PACKAGE_boost-system),--with-system) \ + $(if $(CONFIG_PACKAGE_boost-test),--with-test) \ + $(if $(CONFIG_PACKAGE_boost-thread),--with-thread) \ + $(if $(CONFIG_PACKAGE_boost-wave),--with-wave) \ + \ + $(if $(CONFIG_PACKAGE_boost-iostreams),-sNO_BZIP2=1 -sZLIB_INCLUDE=$(STAGING_DIR)/usr/include \ + -sZLIB_LIBPATH=$(STAGING_DIR)/usr/lib) \ install \ ) endef -define Package/boost/description - Boost provides free peer-reviewed portable C++ source libraries +define Build/InstallDev + $(INSTALL_DIR) $(1)/usr/include/boost/ + $(CP) $(PKG_INSTALL_DIR)/include/boost/* $(1)/usr/include/boost/ # copies _all_ header files - independent of <--with-library>-argument above + + if [ -d $(PKG_INSTALL_DIR)/lib ]; then \ + $(INSTALL_DIR) $(1)/usr/lib; \ + $(CP) $(PKG_INSTALL_DIR)/lib/*.a $(1)/usr/lib/; \ + $(CP) $(PKG_INSTALL_DIR)/lib/*.so* $(1)/usr/lib/; \ + fi +endef + +define Package/boost/Default/install + $(INSTALL_DIR) $(1)/usr/lib + $(CP) $(PKG_INSTALL_DIR)/lib/libboost_$(2)*.so* $(1)/usr/lib/ endef -define Build/InstallDev - $(INSTALL_DIR) $(1)/usr/include/boost $(1)/usr/lib - $(CP) $(PKG_INSTALL_DIR)/include/boost-*/boost/* $(1)/usr/include/boost/ # copies _all_ header files - independent of <--with-library>-argument above - $(CP) $(PKG_INSTALL_DIR)/lib/*.a $(1)/usr/lib/ +define Package/boost-date_time/install + $(call Package/boost/Default/install,$(1),date_time) endef -define Package/boost/install - $(INSTALL_DIR) $(1)/usr/lib - $(CP) $(PKG_INSTALL_DIR)/lib/*.so* $(1)/usr/lib/ +define Package/boost-filesystem/install + $(call Package/boost/Default/install,$(1),filesystem) endef -# TODO: Split libboost into several smaller packages +define Package/boost-graph/install + $(call Package/boost/Default/install,$(1),graph) +endef + +define Package/boost-iostreams/install + $(call Package/boost/Default/install,$(1),iostreams) +endef + +define Package/boost-math/install + $(call Package/boost/Default/install,$(1),math) +endef -#define Package/boost-serialization/install -# $(INSTALL_DIR) $(1)/usr/lib -# $(CP) $(PKG_INSTALL_DIR)/lib/*serialization*.so* $(1)/usr/lib/ +#define Package/boost-mpi/install +# $(call Package/boost/Default/install,$(1),mpi) #endef +define Package/boost-program_options/install + $(call Package/boost/Default/install,$(1),program_options) +endef + +define Package/boost-python/install + $(call Package/boost/Default/install,$(1),python) +endef + +define Package/boost-regex/install + $(call Package/boost/Default/install,$(1),regex) +endef + +define Package/boost-serialization/install + $(call Package/boost/Default/install,$(1),serialization) +endef + +define Package/boost-signals/install + $(call Package/boost/Default/install,$(1),signals) +endef + +define Package/boost-system/install + $(call Package/boost/Default/install,$(1),system) +endef + +define Package/boost-test/install + $(INSTALL_DIR) $(1)/usr/lib + $(CP) $(PKG_INSTALL_DIR)/lib/libboost_unit_test_framework*.so* $(1)/usr/lib/ + $(CP) $(PKG_INSTALL_DIR)/lib/libboost_prg_exec_monitor*.so* $(1)/usr/lib/ +endef + +define Package/boost-thread/install + $(call Package/boost/Default/install,$(1),thread) +endef + +define Package/boost-wave/install + $(call Package/boost/Default/install,$(1),wave) +endef + $(eval $(call BuildPackage,boost)) +$(eval $(call BuildPackage,boost-date_time)) +$(eval $(call BuildPackage,boost-filesystem)) +$(eval $(call BuildPackage,boost-function_types)) +$(eval $(call BuildPackage,boost-graph)) +$(eval $(call BuildPackage,boost-iostreams)) +$(eval $(call BuildPackage,boost-math)) +#$(eval $(call BuildPackage,boost-mpi)) +$(eval $(call BuildPackage,boost-program_options)) +$(eval $(call BuildPackage,boost-python)) +$(eval $(call BuildPackage,boost-regex)) +$(eval $(call BuildPackage,boost-serialization)) +$(eval $(call BuildPackage,boost-signals)) +$(eval $(call BuildPackage,boost-system)) +$(eval $(call BuildPackage,boost-test)) +$(eval $(call BuildPackage,boost-thread)) +$(eval $(call BuildPackage,boost-wave))