# Copyright 1999-2008 Gentoo Foundation # Distributed under the terms of the GNU General Public License v2 # $Header: /var/cvsroot/gentoo-x86/dev-libs/boost/boost-1.35.0-r1.ebuild,v 1.3 2008/06/16 04:49:39 jer Exp $ inherit python flag-o-matic multilib toolchain-funcs versionator check-reqs KEYWORDS="~alpha ~amd64 ~arm ~hppa ~ia64 ~mips ~ppc ~ppc64 ~s390 ~sh ~sparc ~x86" MY_P=${PN}_$(replace_all_version_separators _) PATCHSET_VERSION="${PV}-2" DESCRIPTION="Boost Libraries for C++" HOMEPAGE="http://www.boost.org/" SRC_URI="mirror://sourceforge/boost/${MY_P}.tar.bz2 mirror://gentoo/boost-patches-${PATCHSET_VERSION}.tbz2" LICENSE="freedist Boost-1.0" SLOT="0" IUSE="debug doc expat icu mpi tools" RDEPEND="icu? ( >=dev-libs/icu-3.3 ) expat? ( dev-libs/expat ) mpi? ( || ( sys-cluster/openmpi sys-cluster/mpich2 ) ) sys-libs/zlib virtual/python" DEPEND="${RDEPEND} >=dev-util/boost-build-${PV}-r1" S=${WORKDIR}/${MY_P} # Maintainer Information # ToDo: # - write a patch to support /dev/urandom on FreeBSD and OSX (see below) pkg_setup() { if has test ${FEATURES} ; then CHECKREQS_DISK_BUILD="1024" check_reqs ewarn "The tests may take several hours on a recent machine" ewarn "but they will not fail (unless something weird happens ;-)" ewarn "This is because the tests depend on the used compiler/-version" ewarn "and the platform and upstream says that this is normal." ewarn "If you are interested in the results, please take a look at the" ewarn "generated results page:" ewarn " ${ROOT}usr/share/doc/${PF}/status/cs-$(uname).html" ebeep 5 fi } src_unpack() { unpack ${A} cd "${S}" EPATCH_SOURCE="${WORKDIR}/patches" EPATCH_SUFFIX="patch" epatch # This enables building the boost.random library with /dev/urandom support if ! use userland_Darwin ; then mkdir -p libs/random/build cp "${FILESDIR}/random-Jamfile" libs/random/build/Jamfile.v2 fi } generate_options() { # Maintainer information: # The debug-symbols=none and optimization=none # are not official upstream flags but a Gentoo # specific patch to make sure that all our # CXXFLAGS/LDFLAGS are being respected. # Using optimization=off would for example add # "-O0" and override "-O2" set by the user. # Please take a look at the boost-build ebuild # for more infomration. OPTIONS="gentoorelease" use debug && OPTIONS="gentoodebug" use icu && OPTIONS="${OPTIONS} -sICU_PATH=/usr" if use expat ; then OPTIONS="${OPTIONS} -sEXPAT_INCLUDE=/usr/include -sEXPAT_LIBPATH=/usr/$(get_libdir)" fi if ! use mpi ; then OPTIONS="${OPTIONS} --without-mpi" fi OPTIONS="${OPTIONS} --user-config=${S}/user-config.jam --boost-build=/usr/share/boost-build" } generate_userconfig() { einfo "Writing new user-config.jam" python_version local compiler compilerVersion compilerExecutable if [[ ${CHOST} == *-darwin* ]] ; then compiler=darwin compilerVersion=$(gcc-version) compilerExecutable=$(tc-getCXX) append-ldflags -ldl else compiler=gcc compilerVersion=$(gcc-version) compilerExecutable=$(tc-getCXX) fi cat > "${S}/user-config.jam" << __EOF__ variant gentoorelease : release : none none ; variant gentoodebug : debug : none none ; using ${compiler} : ${compilerVersion} : ${compilerExecutable} : "${CXXFLAGS}" "${LDFLAGS}" ; using python : ${PYVER} : /usr : /usr/include/python${PYVER} : /usr/lib/python${PYVER} ; __EOF__ if use mpi ; then echo "using mpi ;" >> "${S}/user-config.jam" fi } src_compile() { NUMJOBS=$(sed -e 's/.*\(\-j[ 0-9]\+\) .*/\1/' <<< ${MAKEOPTS}) generate_userconfig generate_options elog "Using the following options to build: " elog " ${OPTIONS}" export BOOST_ROOT=${S} bjam ${NUMJOBS} -q \ ${OPTIONS} \ threading=single,multi link=shared,static runtime-link=shared,static \ --prefix="${D}/usr" \ --layout=system \ || die "building boost failed" if use tools; then cd "${S}/tools/" # We have to set optimization to -O0 or -O1 to work around a gcc-bug # optimization=off adds -O0 to the compiler call and overwrites our settings. bjam ${NUMJOBS} -q \ ${OPTIONS} \ --prefix="${D}/usr" \ --layout=system \ || die "building tools failed" fi if has test ${FEATURES} ; then cd "${S}/tools/regression/build" bjam -q \ ${OPTIONS} \ --prefix="${D}/usr" \ --layout=system \ || die "building regression test helpers failed" fi } src_install () { generate_options export BOOST_ROOT=${S} bjam -q \ ${OPTIONS} \ threading=single,multi link=shared,static runtime-link=shared,static \ --prefix="${D}/usr" \ --includedir="${D}/usr/include" \ --libdir="${D}/usr/$(get_libdir)" \ --layout=system \ install || die "install failed for options '${OPTIONS}'" # Move the mpi.so to the right place if use mpi; then mkdir -p "${D}/usr/$(get_libdir)/python${PYVER}/site-packages" mv "${D}/usr/$(get_libdir)/mpi.so" "${D}/usr/$(get_libdir)/python${PYVER}/site-packages" fi if use doc ; then find libs -iname "test" -or -iname "src" | xargs rm -rf dohtml \ -A pdf,txt,cpp \ *.{htm,html,png,css} \ -r doc more people wiki insinto /usr/share/doc/${PF}/html doins -r libs # To avoid broken links insinto /usr/share/doc/${PF}/html doins LICENSE_1_0.txt dosym /usr/include/boost /usr/share/doc/${PF}/html/boost fi cd "${D}/usr/$(get_libdir)" # If built with debug enabled, all libraries get a 'd' postfix, # this breaks linking other apps against boost (bug #181972) if use debug ; then for lib in $(ls -1 libboost_*) ; do dosym ${lib} "/usr/$(get_libdir)/$(sed -e 's/-d\././' -e 's/d\././' <<< ${lib})" done fi for lib in $(ls -1 libboost_thread-mt.*) ; do dosym ${lib} "/usr/$(get_libdir)/$(sed -e 's/-mt//' <<< ${lib})" done if use tools; then cd "${S}/dist" dobin bin/* insinto /usr doins -r share fi if has test ${FEATURES} ; then cd "${S}/status" docinto status dohtml *.{html,gif} ../boost.png dodoc regress.log fi } src_test() { generate_options export BOOST_ROOT=${S} cd "${S}/status" # Some of the test-checks seem to rely on regexps export LC_ALL="C" # The following is largely taken from tools/regression/run_tests.sh, # but adapted to our needs. # Run the tests & write them into a file for postprocessing bjam \ ${OPTIONS} \ --dump-tests 2>&1 | tee regress.log # Postprocessing cat regress.log | "${S}/dist/bin/process_jam_log" --v2 if test $? != 0 ; then die "Postprocessing the build log failed" fi cat > "${S}/status/comment.html" <<- __EOF__

Tests are run on a Gentoo system.

__EOF__ # Generate the build log html summary page "${S}/dist/bin/compiler_status" --v2 \ --comment "${S}/status/comment.html" "${S}" \ cs-$(uname).html cs-$(uname)-links.html if test $? != 0 ; then die "Generating the build log html summary page failed" fi # And do some cosmetic fixes :) sed -i -e 's|../boost.png|boost.png|' *.html }