/[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.9 Revision 1.17
1# Copyright 1999-2012 Gentoo Foundation 1# Copyright 1999-2012 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.9 2012/04/16 07:54:18 ssuominen Exp $ 3# $Header: /var/cvsroot/gentoo-x86/eclass/waf-utils.eclass,v 1.17 2012/12/06 09:28:11 scarabeus Exp $
4 4
5# @ECLASS: waf-utils.eclass 5# @ECLASS: waf-utils.eclass
6# @MAINTAINER: 6# @MAINTAINER:
7# gnome@gentoo.org 7# gnome@gentoo.org
8# @AUTHOR: 8# @AUTHOR:
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 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
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
27# slots that have USE=-threads.
28DEPEND="${DEPEND}
29 dev-lang/python
30 !dev-lang/python[-threads]"
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}
24 37
25# @FUNCTION: waf-utils_src_configure 38# @FUNCTION: waf-utils_src_configure
26# @DESCRIPTION: 39# @DESCRIPTION:
27# General function for configuring with waf. 40# General function for configuring with waf.
28waf-utils_src_configure() { 41waf-utils_src_configure() {
29 debug-print-function ${FUNCNAME} "$@" 42 debug-print-function ${FUNCNAME} "$@"
30 43
44 local libdir=""
45
31 # @ECLASS-VARIABLE: WAF_BINARY 46 # @ECLASS-VARIABLE: WAF_BINARY
32 # @DESCRIPTION: 47 # @DESCRIPTION:
33 # 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".
34 : ${WAF_BINARY:="${S}/waf"} 49 : ${WAF_BINARY:="${S}/waf"}
35 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
36 tc-export AR CC CPP CXX RANLIB 58 tc-export AR CC CPP CXX RANLIB
37 echo "CCFLAGS=\"${CFLAGS}\" LINKFLAGS=\"${LDFLAGS}\" \"${WAF_BINARY}\" --prefix=${EPREFIX}/usr --libdir=${EPREFIX}/usr/$(get_libdir) $@ configure" 59 echo "CCFLAGS=\"${CFLAGS}\" LINKFLAGS=\"${LDFLAGS}\" \"${WAF_BINARY}\" --prefix=${EPREFIX}/usr ${libdir} $@ configure"
38 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
39 CCFLAGS="${CFLAGS}" LINKFLAGS="${LDFLAGS}" "${WAF_BINARY}" \ 64 CCFLAGS="${CFLAGS}" LINKFLAGS="${LDFLAGS}" "${WAF_BINARY}" \
40 "--prefix=${EPREFIX}/usr" \ 65 "--prefix=${EPREFIX}/usr" \
41 "--libdir=${EPREFIX}/usr/$(get_libdir)" \ 66 "${libdir}" \
42 "$@" \ 67 "$@" \
43 configure || die "configure failed" 68 configure || die "configure failed"
69 else
70 CCFLAGS="${CFLAGS}" LINKFLAGS="${LDFLAGS}" "${WAF_BINARY}" \
71 "--prefix=${EPREFIX}/usr" \
72 "$@" \
73 configure || die "configure failed"
74 fi
44} 75}
45 76
46# @FUNCTION: waf-utils_src_compile 77# @FUNCTION: waf-utils_src_compile
47# @DESCRIPTION: 78# @DESCRIPTION:
48# General function for compiling with waf. 79# General function for compiling with waf.
49waf-utils_src_compile() { 80waf-utils_src_compile() {
50 debug-print-function ${FUNCNAME} "$@" 81 debug-print-function ${FUNCNAME} "$@"
82 local _mywafconfig
83 [[ "${WAF_VERBOSE}" ]] && _mywafconfig="--verbose"
51 84
52 local jobs="--jobs=$(makeopts_jobs)" 85 local jobs="--jobs=$(makeopts_jobs)"
53 echo "\"${WAF_BINARY}\" build ${jobs}" 86 echo "\"${WAF_BINARY}\" build ${_mywafconfig} ${jobs}"
54 "${WAF_BINARY}" ${jobs} || die "build failed" 87 "${WAF_BINARY}" ${_mywafconfig} ${jobs} || die "build failed"
55} 88}
56 89
57# @FUNCTION: waf-utils_src_install 90# @FUNCTION: waf-utils_src_install
58# @DESCRIPTION: 91# @DESCRIPTION:
59# Function for installing the package. 92# Function for installing the package.

Legend:
Removed from v.1.9  
changed lines
  Added in v.1.17

  ViewVC Help
Powered by ViewVC 1.1.20