diff options
author | Tiziano Müller <dev-zero@gentoo.org> | 2008-04-24 15:01:21 +0000 |
---|---|---|
committer | Tiziano Müller <dev-zero@gentoo.org> | 2008-04-24 15:01:21 +0000 |
commit | b184b0b8e0f42d9aee1942e87b62c01836b0a74c (patch) | |
tree | 27a4d6156c0802c2122d9d264de1b7a0c0723f22 /dev-libs | |
parent | Change rb_libtorrent dep. to ~0.12. (diff) | |
download | gentoo-2-b184b0b8e0f42d9aee1942e87b62c01836b0a74c.tar.gz gentoo-2-b184b0b8e0f42d9aee1942e87b62c01836b0a74c.tar.bz2 gentoo-2-b184b0b8e0f42d9aee1942e87b62c01836b0a74c.zip |
Version bump (but not finished yet).
(Portage version: 2.1.5_rc4)
Diffstat (limited to 'dev-libs')
-rw-r--r-- | dev-libs/boost/ChangeLog | 7 | ||||
-rw-r--r-- | dev-libs/boost/boost-1.35.0.ebuild | 274 |
2 files changed, 280 insertions, 1 deletions
diff --git a/dev-libs/boost/ChangeLog b/dev-libs/boost/ChangeLog index 2d096ed36407..8432a5b388b1 100644 --- a/dev-libs/boost/ChangeLog +++ b/dev-libs/boost/ChangeLog @@ -1,6 +1,11 @@ # ChangeLog for dev-libs/boost # Copyright 2002-2008 Gentoo Foundation; Distributed under the GPL v2 -# $Header: /var/cvsroot/gentoo-x86/dev-libs/boost/ChangeLog,v 1.133 2008/02/05 15:42:08 drac Exp $ +# $Header: /var/cvsroot/gentoo-x86/dev-libs/boost/ChangeLog,v 1.134 2008/04/24 15:01:21 dev-zero Exp $ + +*boost-1.35.0 (24 Apr 2008) + + 24 Apr 2008; Tiziano Müller <dev-zero@gentoo.org> +boost-1.35.0.ebuild: + Version bump (but not finished yet). 05 Feb 2008; Samuli Suominen <drac@gentoo.org> boost-1.34.1-r2.ebuild: amd64 stable wrt security #205955 diff --git a/dev-libs/boost/boost-1.35.0.ebuild b/dev-libs/boost/boost-1.35.0.ebuild new file mode 100644 index 000000000000..60f88b05f227 --- /dev/null +++ b/dev-libs/boost/boost-1.35.0.ebuild @@ -0,0 +1,274 @@ +# 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.ebuild,v 1.1 2008/04/24 15:01:21 dev-zero Exp $ + +inherit distutils 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}-1" + +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 icu pyste tools" + +DEPEND="icu? ( >=dev-libs/icu-3.2 ) + sys-libs/zlib + ~dev-util/boost-build-${PV}" +RDEPEND="${DEPEND} + pyste? ( dev-cpp/gccxml dev-python/elementtree )" + +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 + + rm boost-build.jam + + # 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() { + LINK_OPTIONS="static shared" + + # 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. + if ! use debug ; then + OPTIONS="release debug-symbols=none" + else + OPTIONS="debug" + fi + + OPTIONS="${OPTIONS} optimization=none" + + use icu && OPTIONS="${OPTIONS} -sHAVE_ICU=1 -sICU_PATH=/usr" + + OPTIONS="${OPTIONS} --user-config=${S}/user-config.jam" +} + +generate_userconfig() { + einfo "Writing new user-config.jam" + distutils_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__ +import toolset : using ; +import toolset : flags ; +using ${compiler} : ${compilerVersion} : ${compilerExecutable} : <cxxflags>"${CXXFLAGS}" <linkflags>"${LDFLAGS}" ; +using python : ${PYVER} : /usr : /usr/include/python${PYVER} : /usr/lib/python${PYVER} ; +__EOF__ + +} + +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} + export BOOST_BUILD_PATH=/usr/share/boost-build + + for linkoption in ${LINK_OPTIONS} ; do + einfo "Building ${linkoption} libraries" + bjam ${NUMJOBS} -q \ + ${OPTIONS} \ + threading=single,multi \ + runtime-link=${linkoption} link=${linkoption} \ + --prefix="${D}/usr" \ + --layout=system \ + || die "building boost failed" + done + + if use pyste; then + cd "${S}/libs/python/pyste/install" + distutils_src_compile + fi + + 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 \ + release debug-symbols=none \ + optimization=off \ + --prefix="${D}/usr" \ + --layout=system \ + --user-config="${S}/user-config.jam" \ + || 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} + export BOOST_BUILD_PATH=/usr/share/boost-build + + for linkoption in ${LINK_OPTIONS} ; do + bjam -q \ + ${OPTIONS} \ + threading=single,multi \ + runtime-link=${linkoption} link=${linkoption} \ + --prefix="${D}/usr" \ + --includedir="${D}/usr/include" \ + --libdir="${D}/usr/$(get_libdir)" \ + --layout=system \ + install || die "install failed" + done + + if use doc ; then + dohtml -A pdf,txt \ + *.htm *.png *.css \ + -r doc libs more people wiki + + # 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 pyste; then + cd "${S}/libs/python/pyste/install" + distutils_src_install + fi + + 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} + export BOOST_BUILD_PATH=/usr/share/boost-build + + 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__ + <p>Tests are run on a <a href="http://www.gentoo.org">Gentoo</a> system.</p> +__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 +} |