/[gentoo-x86]/eclass/waf-utils.eclass
Gentoo

Diff of /eclass/waf-utils.eclass

Parent Directory Parent Directory | Revision Log Revision Log | View Patch Patch

Revision 1.13 Revision 1.20
1# Copyright 1999-2012 Gentoo Foundation 1# Copyright 1999-2014 Gentoo Foundation
2# Distributed under the terms of the GNU General Public License v2 2# Distributed under the terms of the GNU General Public License v2
3# $Header: /var/cvsroot/gentoo-x86/eclass/waf-utils.eclass,v 1.13 2012/07/20 01:37:43 vapier Exp $ 3# $Header: /var/cvsroot/gentoo-x86/eclass/waf-utils.eclass,v 1.20 2014/12/25 23:35:18 eva Exp $
4 4
5# @ECLASS: waf-utils.eclass 5# @ECLASS: waf-utils.eclass
6# @MAINTAINER: 6# @MAINTAINER:
7# gnome@gentoo.org 7# maintainer-needed@gentoo.org
8# @AUTHOR: 8# @AUTHOR:
9# Original Author: Gilles Dartiguelongue <eva@gentoo.org> 9# Original Author: Gilles Dartiguelongue <eva@gentoo.org>
10# Various improvements based on cmake-utils.eclass: Tomáš Chvátal <scarabeus@gentoo.org> 10# Various improvements based on cmake-utils.eclass: Tomáš Chvátal <scarabeus@gentoo.org>
11# Proper prefix support: Jonathan Callen <abcd@gentoo.org> 11# Proper prefix support: Jonathan Callen <jcallen@gentoo.org>
12# @BLURB: common ebuild functions for waf-based packages 12# @BLURB: common ebuild functions for waf-based packages
13# @DESCRIPTION: 13# @DESCRIPTION:
14# The waf-utils eclass contains functions that make creating ebuild for 14# The waf-utils eclass contains functions that make creating ebuild for
15# waf-based packages much easier. 15# waf-based packages much easier.
16# Its main features are support of common portage default settings. 16# Its main features are support of common portage default settings.
17 17
18inherit base eutils multilib toolchain-funcs multiprocessing 18inherit base eutils multilib toolchain-funcs multiprocessing
19 19
20case ${EAPI:-0} in 20case ${EAPI:-0} in
21 4|3) EXPORT_FUNCTIONS src_configure src_compile src_install ;; 21 3|4|5) EXPORT_FUNCTIONS src_configure src_compile src_install ;;
22 *) die "EAPI=${EAPI} is not supported" ;; 22 *) die "EAPI=${EAPI} is not supported" ;;
23esac 23esac
24 24
25# Python with threads is required to run waf. We do not know which python slot 25# Python with threads is required to run waf. We do not know which python slot
26# is being used as the system interpreter, so we are forced to block all 26# is being used as the system interpreter, so we are forced to block all
27# slots that have USE=-threads. 27# slots that have USE=-threads.
28DEPEND="${DEPEND} 28DEPEND="${DEPEND}
29 dev-lang/python 29 dev-lang/python
30 !dev-lang/python[-threads]" 30 !dev-lang/python[-threads]"
31 31
32# @ECLASS-VARIABLE: WAF_VERBOSE
33# @DESCRIPTION:
34# Set to OFF to disable verbose messages during compilation
35# this is _not_ meant to be set in ebuilds
36: ${WAF_VERBOSE:=ON}
37
32# @FUNCTION: waf-utils_src_configure 38# @FUNCTION: waf-utils_src_configure
33# @DESCRIPTION: 39# @DESCRIPTION:
34# General function for configuring with waf. 40# General function for configuring with waf.
35waf-utils_src_configure() { 41waf-utils_src_configure() {
36 debug-print-function ${FUNCNAME} "$@" 42 debug-print-function ${FUNCNAME} "$@"
37 43
44 local libdir=""
45
38 # @ECLASS-VARIABLE: WAF_BINARY 46 # @ECLASS-VARIABLE: WAF_BINARY
39 # @DESCRIPTION: 47 # @DESCRIPTION:
40 # Eclass can use different waf executable. Usually it is located in "${S}/waf". 48 # Eclass can use different waf executable. Usually it is located in "${S}/waf".
41 : ${WAF_BINARY:="${S}/waf"} 49 : ${WAF_BINARY:="${S}/waf"}
42 50
51 # @ECLASS-VARIABLE: NO_WAF_LIBDIR
52 # @DEFAULT_UNSET
53 # @DESCRIPTION:
54 # Variable specifying that you don't want to set the libdir for waf script.
55 # Some scripts does not allow setting it at all and die if they find it.
56 [[ -z ${NO_WAF_LIBDIR} ]] && libdir="--libdir=${EPREFIX}/usr/$(get_libdir)"
57
43 tc-export AR CC CPP CXX RANLIB 58 tc-export AR CC CPP CXX RANLIB
44 echo "CCFLAGS=\"${CFLAGS}\" LINKFLAGS=\"${LDFLAGS}\" \"${WAF_BINARY}\" --prefix=${EPREFIX}/usr --libdir=${EPREFIX}/usr/$(get_libdir) $@ configure" 59 echo "CCFLAGS=\"${CFLAGS}\" LINKFLAGS=\"${CFLAGS} ${LDFLAGS}\" \"${WAF_BINARY}\" --prefix=${EPREFIX}/usr ${libdir} $@ configure"
45 60
61 # This condition is required because waf takes even whitespace as function
62 # calls, awesome isn't it?
63 if [[ -z ${NO_WAF_LIBDIR} ]]; then
46 CCFLAGS="${CFLAGS}" LINKFLAGS="${LDFLAGS}" "${WAF_BINARY}" \ 64 CCFLAGS="${CFLAGS}" LINKFLAGS="${CFLAGS} ${LDFLAGS}" "${WAF_BINARY}" \
47 "--prefix=${EPREFIX}/usr" \ 65 "--prefix=${EPREFIX}/usr" \
48 "--libdir=${EPREFIX}/usr/$(get_libdir)" \ 66 "${libdir}" \
49 "$@" \ 67 "$@" \
50 configure || die "configure failed" 68 configure || die "configure failed"
69 else
70 CCFLAGS="${CFLAGS}" LINKFLAGS="${CFLAGS} ${LDFLAGS}" "${WAF_BINARY}" \
71 "--prefix=${EPREFIX}/usr" \
72 "$@" \
73 configure || die "configure failed"
74 fi
51} 75}
52 76
53# @FUNCTION: waf-utils_src_compile 77# @FUNCTION: waf-utils_src_compile
54# @DESCRIPTION: 78# @DESCRIPTION:
55# General function for compiling with waf. 79# General function for compiling with waf.
56waf-utils_src_compile() { 80waf-utils_src_compile() {
57 debug-print-function ${FUNCNAME} "$@" 81 debug-print-function ${FUNCNAME} "$@"
82 local _mywafconfig
83 [[ "${WAF_VERBOSE}" ]] && _mywafconfig="--verbose"
58 84
59 local jobs="--jobs=$(makeopts_jobs)" 85 local jobs="--jobs=$(makeopts_jobs)"
60 echo "\"${WAF_BINARY}\" build ${jobs}" 86 echo "\"${WAF_BINARY}\" build ${_mywafconfig} ${jobs}"
61 "${WAF_BINARY}" ${jobs} || die "build failed" 87 "${WAF_BINARY}" ${_mywafconfig} ${jobs} || die "build failed"
62} 88}
63 89
64# @FUNCTION: waf-utils_src_install 90# @FUNCTION: waf-utils_src_install
65# @DESCRIPTION: 91# @DESCRIPTION:
66# Function for installing the package. 92# Function for installing the package.

Legend:
Removed from v.1.13  
changed lines
  Added in v.1.20

  ViewVC Help
Powered by ViewVC 1.1.20