package/boost: disable boost-locale for static only build with icu
authorRomain Naour <romain.naour@gmail.com>
Sun, 14 May 2017 21:45:56 +0000 (23:45 +0200)
committerThomas Petazzoni <thomas.petazzoni@free-electrons.com>
Tue, 16 May 2017 07:45:35 +0000 (09:45 +0200)
Boost fails to build with the following error:

error: Tried to build the target twice, with property sets having
error: these incompatible properties:
error:
error:     -  <runtime-link>static <warnings>all
error:     -  <runtime-link>shared <warnings>on

when the following conditions are met:

 - BR2_STATIC_LIBS=y
 - BR2_PACKAGE_ICU=y
 - BR2_PACKAGE_BOOST_LOCALE=y
 - Another BR2_PACKAGE_BOOST_xyz option is enabled, which enables a
   feature not provided just by header files, but that requires
   building a library.

In such a situation, Boost absolutely wants to build the libboost
libraries as shared libraries. Not having boost-locale, or not having
icu is sufficient to avoid the issue.

So, as a simple work-around, we prevent from building boost-locale
when icu and static linking are used.

Fixes:

  http://autobuild.buildroot.net/results/c8f7aa85f5791d8ae8cf4b9085788adc5152286f/

Signed-off-by: Romain Naour <romain.naour@gmail.com>
Cc: Yegor Yefremov <yegorslists@googlemail.com>
Cc: Thomas Petazzoni <thomas.petazzoni@free-electrons.com>
[Thomas:
 - only disable boost-locale when icu is enabled
 - improve commit log]
Signed-off-by: Thomas Petazzoni <thomas.petazzoni@free-electrons.com>
package/boost/Config.in

index 9825c09ad2852b491757c98c44813e7b6a91c402..f0a23857067a3c504402256b7530f498494a436b 100644 (file)
@@ -98,8 +98,21 @@ config BR2_PACKAGE_BOOST_IOSTREAMS
 
 config BR2_PACKAGE_BOOST_LOCALE
        bool "boost-locale"
+       # When boost-locale is enabled with icu support, Boost no
+       # longer supports building the libboost_* libraries as static
+       # libraries, causing build failures when other boost features
+       # than boost-locale are enabled. To work around this, we
+       # prevent using boost-locale on static linking configurations
+       # with icu enabled. See
+       # https://svn.boost.org/trac/boost/ticket/9685 for more
+       # details.
+       depends on !(BR2_STATIC_LIBS && BR2_PACKAGE_ICU)
        select BR2_PACKAGE_LIBICONV if !BR2_ENABLE_LOCALE
 
+comment "boost-locale needs a toolchain w/ dynamic library"
+       depends on BR2_PACKAGE_ICU
+       depends on BR2_STATIC_LIBS
+
 config BR2_PACKAGE_BOOST_LOG
        bool "boost-log"
        depends on BR2_TOOLCHAIN_HAS_THREADS_NPTL