# Copyright 1999-2013 Gentoo Foundation # Distributed under the terms of the GNU General Public License v2 # $Header: /var/cvsroot/gentoo-x86/dev-python/pycairo/pycairo-1.10.0-r4.ebuild,v 1.4 2013/01/14 17:29:27 bicatali Exp $ EAPI="5" PYTHON_COMPAT=( python2_{6,7} python3_{1,2,3} ) inherit eutils python-r1 waf-utils PYCAIRO_PYTHON2_VERSION="${PV}" PYCAIRO_PYTHON3_VERSION="${PV}" DESCRIPTION="Python bindings for the cairo library" HOMEPAGE="http://cairographics.org/pycairo/ http://pypi.python.org/pypi/pycairo" SRC_URI="http://cairographics.org/releases/py2cairo-${PYCAIRO_PYTHON2_VERSION}.tar.bz2 http://cairographics.org/releases/pycairo-${PYCAIRO_PYTHON3_VERSION}.tar.bz2 http://dev.gentoo.org/~binki/distfiles/dev-python/${PN}/${P}-waf-multilib.patch" # LGPL-3 for pycairo 1.10.0. # || ( LGPL-2.1 MPL-1.1 ) for pycairo 1.8.10. LICENSE="LGPL-3 || ( LGPL-2.1 MPL-1.1 )" SLOT="0" KEYWORDS="~alpha amd64 arm ~hppa ia64 ~mips ppc ppc64 ~sparc x86 ~amd64-fbsd ~amd64-linux ~x86-fbsd ~ppc-macos ~x64-macos ~x86-linux ~x86-macos" IUSE="doc examples +svg test xcb" RDEPEND=" >=x11-libs/cairo-1.10.0[svg?,xcb?] xcb? ( x11-libs/xpyb ) " DEPEND="${RDEPEND} virtual/pkgconfig test? ( dev-python/pytest[${PYTHON_USEDEP}] ) " PYTHON_CFLAGS=("2.* + -fno-strict-aliasing") # In case if waf-utils.eclass actually accepts waf-utils_waflibdir() as # a function. unset waf-utils_waflibdir 2>/dev/null # @FUNCTION: waf-utils_waflibdir # @USAGE: [] # @DESCRIPTION: # Echoes the absolute path to the directory containing waf-based # project's waflib python module. Ensures that the waflib shipped with a # project is unpacked if it isn't already. This waflib may be safely # patched because waf-lite will not touch the waflib directory when it # is run if it already exists. Uses the waf binary in WAF_BINARY or the # first argument. # # @EXAMPLE # @CODE # pushd "$(waf-utils_waflibdir)" || die "Unable to patch waflib" # epatch "${FILESDIR}"/${P}-waf-fix.patch # popd # @CODE # # Note that if you are using the python eclass, you must either call # python_set_active_version or call waf-utils_waflibdir() from within a # function run by python_execute(). # # @CODE # SUPPORT_PYTHON_ABIS=1 # inherit python # # src_prepare() { # python_copy_sources # # myprepare() { # epatch "${FILESDIR}"/${P}-sourcecode-fix.patch # # pushd "$(waf-utils_saflibdir "$(PYTHON)" waf)" || die "Unable to patch waflib" # epatch "${FILESDIR}"/${P}-waf-fix.patch # popd # } # python_execute_function -s myprepare # } # @CODE waf-utils_waflibdir() { debug-print-function ${FUNCNAME} "$@" # @ECLASS-VARIABLE: WAF_BINARY # @DESCRIPTION: # Eclass can use different waf executable. Usually it is located in "${S}/waf". : ${WAF_BINARY:="${S}/waf"} local waf_binary=${WAF_BINARY} [[ -n ${1} ]] && waf_binary=${1} python -c "import imp, sys; sys.argv[0] = '${waf_binary}'; waflite = imp.load_source('waflite', '${waf_binary}'); print(waflite.find_lib());" \ || die "Unable to locate or unpack waflib module from the waf script at ${waf_binary}" } # When moving between the different build dirs, we want to use the waf # associated with each build dir. WAF_BINARY=./waf src_prepare() { pushd "${WORKDIR}/pycairo-${PYCAIRO_PYTHON3_VERSION}" > /dev/null rm -f src/config.h || die epatch "${FILESDIR}/${PN}-1.10.0-svg_check.patch" epatch "${FILESDIR}/${PN}-1.10.0-xpyb.patch" epatch "${FILESDIR}"/py2cairo-1.10.0-ppc-darwin.patch cd "$(waf-utils_waflibdir waf)" || die "Unable to patch waflib" epatch "${DISTDIR}"/${P}-waf-multilib.patch popd > /dev/null pushd "${WORKDIR}/py2cairo-${PYCAIRO_PYTHON2_VERSION}" > /dev/null rm -f src/config.h || die epatch "${FILESDIR}/py2cairo-1.10.0-svg_check.patch" epatch "${FILESDIR}/py2cairo-1.10.0-xpyb.patch" epatch "${FILESDIR}"/py2cairo-1.10.0-ppc-darwin.patch cd "$(waf-utils_waflibdir waf)" || die "Unable to patch waflib" epatch "${DISTDIR}"/${P}-waf-multilib.patch popd > /dev/null preparation() { if [[ ${EPYTHON} == python3.* ]]; then cp -r -l "${WORKDIR}/pycairo-${PYCAIRO_PYTHON3_VERSION}" "${BUILD_DIR}" || die else cp -r -l "${WORKDIR}/py2cairo-${PYCAIRO_PYTHON2_VERSION}" "${BUILD_DIR}" || die fi } python_foreach_impl preparation } src_configure() { if ! use svg; then export PYCAIRO_DISABLE_SVG=1 fi if ! use xcb; then export PYCAIRO_DISABLE_XPYB=1 fi # Added by grobian: # If WAF_BINARY is an absolute path, the configure is different and fails to # find Python.h due to a compiler misconfiguration. If WAF_BINARY is just # ./waf or python waf, it works fine. Hooray for reinvented buildsystems # floppym: # pycairo and py2cairo bundle different versions of waf (bug 447856) WAF_BINARY="./waf" python_foreach_impl run_in_build_dir waf-utils_src_configure --nopyc --nopyo } src_compile() { python_foreach_impl run_in_build_dir waf-utils_src_compile } src_test() { test_installation() { ./waf install --destdir="${T}/tests/${BUILD_DIR}" PYTHONPATH="${T}/tests/${BUILD_DIR}$(python_get_sitedir)" py.test -v } python_foreach_impl run_in_build_dir test_installation } src_install() { python_foreach_impl run_in_build_dir waf-utils_src_install dodoc AUTHORS NEWS README if use doc; then pushd doc/_build/html > /dev/null || die dohtml -r [a-z]* _static popd > /dev/null || die fi if use examples; then insinto /usr/share/doc/${PF}/examples doins -r examples/* fi if [[ ${CHOST} == *-darwin* ]] ; then # fix install_names; next to waf producing dylibs (not bundles) and # calling them .bundle, it also has no idea what it should do to create # proper ones (dylibs) fix_darwin_install_names() { local x="$(python_get_sitedir)/cairo/_cairo.bundle" install_name_tool -id "${x}" "${ED}${x}" } python_foreach_impl fix_darwin_install_names fi } run_in_build_dir() { pushd "${BUILD_DIR}" > /dev/null || die "$@" popd > /dev/null || die }