From e3bc35f7891e72ad74e57dc216db899d162373f5 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?J=C3=BCrgen=20Hunold?= Date: Fri, 20 Feb 2015 18:16:38 +0100 Subject: [PATCH] Lift architecture detection --- Jamroot | 7 +++++- boostcpp.jam | 68 +++++++++++++++++++++++++++++++++++++++++++++++++++- 2 files changed, 73 insertions(+), 2 deletions(-) diff --git a/Jamroot b/Jamroot index d1b3c3ad95..dec428c2a7 100644 --- a/Jamroot +++ b/Jamroot @@ -136,7 +136,8 @@ constant BOOST_JAMROOT_MODULE : $(__name__) ; boostcpp.set-version $(BOOST_VERSION) ; - +use-project /boost/architecture : libs/config/checks/architecture ; + local all-headers = [ MATCH .*libs/(.*)/include/boost : [ glob libs/*/include/boost ] ] ; @@ -162,6 +163,10 @@ if $(all-headers) project boost : requirements . + + [ boostcpp.architecture ] + [ boostcpp.address-model ] + # Disable auto-linking for all targets here, primarily because it caused # troubles with V2. BOOST_ALL_NO_LIB=1 diff --git a/boostcpp.jam b/boostcpp.jam index 257e70d459..9c2e28d30b 100644 --- a/boostcpp.jam +++ b/boostcpp.jam @@ -22,7 +22,7 @@ import project ; import regex ; import set ; import targets ; - +import property ; ############################################################################## # @@ -553,3 +553,69 @@ rule declare-targets ( all-libraries * : headers * ) declare_top_level_targets $(libraries) : $(headers) ; } + +rule deduce-address-model ( properties * ) +{ + local result = [ property.select : $(properties) ] ; + if $(result) + { + return $(result) ; + } + else + { + if [ configure.builds /boost/architecture//32 : $(properties) : 32-bit ] + { + return 32 ; + } + else if [ configure.builds /boost/architecture//64 : $(properties) : 64-bit ] + { + return 64 ; + } + } +} + +rule address-model ( ) +{ + return @boostcpp.deduce-address-model ; +} + +rule deduce-architecture ( properties * ) +{ + local result = [ property.select : $(properties) ] ; + if $(result) + { + return $(result) ; + } + else + { + if [ configure.builds /boost/architecture//arm : $(properties) : arm ] + { + return arm ; + } + else if [ configure.builds /boost/architecture//mips1 : $(properties) : mips1 ] + { + return mips1 ; + } + else if [ configure.builds /boost/architecture//power : $(properties) : power ] + { + return power ; + } + else if [ configure.builds /boost/architecture//sparc : $(properties) : sparc ] + { + return sparc ; + } + else if [ configure.builds /boost/architecture//x86 : $(properties) : x86 ] + { + return x86 ; + } + else if [ configure.builds /boost/architecture//combined : $(properties) : combined ] + { + return combined ; + } + } +} + +rule architecture ( ) +{ + return @boostcpp.deduce-architecture ; +}