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

Diff of /eclass/autotools-utils.eclass

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

Revision 1.38 Revision 1.56
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/autotools-utils.eclass,v 1.38 2012/01/14 15:18:05 mgorny Exp $ 3# $Header: /var/cvsroot/gentoo-x86/eclass/autotools-utils.eclass,v 1.56 2012/06/08 17:50:10 mgorny Exp $
4 4
5# @ECLASS: autotools-utils.eclass 5# @ECLASS: autotools-utils.eclass
6# @MAINTAINER: 6# @MAINTAINER:
7# Maciej Mrozowski <reavertm@gentoo.org> 7# Maciej Mrozowski <reavertm@gentoo.org>
8# Michał Górny <mgorny@gentoo.org> 8# Michał Górny <mgorny@gentoo.org>
11# autotools-utils.eclass is autotools.eclass(5) and base.eclass(5) wrapper 11# autotools-utils.eclass is autotools.eclass(5) and base.eclass(5) wrapper
12# providing all inherited features along with econf arguments as Bash array, 12# providing all inherited features along with econf arguments as Bash array,
13# out of source build with overridable build dir location, static archives 13# out of source build with overridable build dir location, static archives
14# handling, libtool files removal. 14# handling, libtool files removal.
15# 15#
16# Please note note that autotools-utils does not support mixing of its phase 16# Please note that autotools-utils does not support mixing of its phase
17# functions with regular econf/emake calls. If necessary, please call 17# functions with regular econf/emake calls. If necessary, please call
18# autotools-utils_src_compile instead of the latter. 18# autotools-utils_src_compile instead of the latter.
19# 19#
20# @EXAMPLE: 20# @EXAMPLE:
21# Typical ebuild using autotools-utils.eclass: 21# Typical ebuild using autotools-utils.eclass:
109# If your tool is not supported, please open a bug and we'll add support for it. 109# If your tool is not supported, please open a bug and we'll add support for it.
110# 110#
111# Note that dependencies are added for autoconf, automake and libtool only. 111# Note that dependencies are added for autoconf, automake and libtool only.
112# If your package needs one of the external tools listed above, you need to add 112# If your package needs one of the external tools listed above, you need to add
113# appropriate packages to DEPEND yourself. 113# appropriate packages to DEPEND yourself.
114[[ ${AUTOTOOLS_AUTORECONF} ]] || _autotools_auto_dep=no 114[[ ${AUTOTOOLS_AUTORECONF} ]] || : ${AUTOTOOLS_AUTO_DEPEND:=no}
115 115
116AUTOTOOLS_AUTO_DEPEND=${_autotools_auto_dep} \
117inherit autotools eutils libtool 116inherit autotools eutils libtool
118 117
119EXPORT_FUNCTIONS src_prepare src_configure src_compile src_install src_test 118EXPORT_FUNCTIONS src_prepare src_configure src_compile src_install src_test
120
121unset _autotools_auto_dep
122 119
123# @ECLASS-VARIABLE: AUTOTOOLS_BUILD_DIR 120# @ECLASS-VARIABLE: AUTOTOOLS_BUILD_DIR
124# @DEFAULT_UNSET 121# @DEFAULT_UNSET
125# @DESCRIPTION: 122# @DESCRIPTION:
126# Build directory, location where all autotools generated files should be 123# Build directory, location where all autotools generated files should be
205# In most cases it's not necessary to manually invoke this function. 202# In most cases it's not necessary to manually invoke this function.
206# See autotools-utils_src_install for reference. 203# See autotools-utils_src_install for reference.
207remove_libtool_files() { 204remove_libtool_files() {
208 debug-print-function ${FUNCNAME} "$@" 205 debug-print-function ${FUNCNAME} "$@"
209 local removing_all 206 local removing_all
207
208 eqawarn "The remove_libtool_files() function was deprecated."
209 eqawarn "Please use prune_libtool_files() from eutils eclass instead."
210
210 [[ ${#} -le 1 ]] || die "Invalid number of args to ${FUNCNAME}()" 211 [[ ${#} -le 1 ]] || die "Invalid number of args to ${FUNCNAME}()"
211 if [[ ${#} -eq 1 ]]; then 212 if [[ ${#} -eq 1 ]]; then
212 case "${1}" in 213 case "${1}" in
213 all) 214 all)
214 removing_all=1 215 removing_all=1
260 if [[ ${removing} ]]; then 261 if [[ ${removing} ]]; then
261 einfo "Removing unnecessary ${f#${D%/}} (${removing})" 262 einfo "Removing unnecessary ${f#${D%/}} (${removing})"
262 rm -f "${f}" || die 263 rm -f "${f}" || die
263 fi 264 fi
264 done 265 done
265
266 # check for invalid eclass use
267 # this is the most commonly used function, so do it here
268 _check_build_dir
269 if [[ ! -d "${AUTOTOOLS_BUILD_DIR}" ]]; then
270 eqawarn "autotools-utils used but autotools-utils_src_configure was never called."
271 eqawarn "This is not supported and never was. Please report a bug against"
272 eqawarn "the offending ebuild. This will become a fatal error in a near future."
273 fi
274} 266}
275 267
276# @FUNCTION: autotools-utils_autoreconf 268# @FUNCTION: autotools-utils_autoreconf
277# @DESCRIPTION: 269# @DESCRIPTION:
278# Reconfigure the sources (like gnome-autogen.sh or eautoreconf). 270# Reconfigure the sources (like gnome-autogen.sh or eautoreconf).
279autotools-utils_autoreconf() { 271autotools-utils_autoreconf() {
280 debug-print-function ${FUNCNAME} "$@" 272 debug-print-function ${FUNCNAME} "$@"
273
274 eqawarn "The autotools-utils_autoreconf() function was deprecated."
275 eqawarn "Please call autotools-utils_src_prepare()"
276 eqawarn "with AUTOTOOLS_AUTORECONF set instead."
281 277
282 # Override this func to not require unnecessary eaclocal calls. 278 # Override this func to not require unnecessary eaclocal calls.
283 autotools_check_macro() { 279 autotools_check_macro() {
284 local x 280 local x
285 281
286 # Add a few additional variants as we don't get expansions. 282 # Add a few additional variants as we don't get expansions.
287 [[ ${1} = AC_CONFIG_HEADERS ]] && set -- "${@}" AC_CONFIG_HEADER 283 [[ ${1} = AC_CONFIG_HEADERS ]] && set -- "${@}" \
284 AC_CONFIG_HEADER AM_CONFIG_HEADER
288 285
289 for x; do 286 for x; do
290 grep -h "^${x}" configure.{ac,in} 2>/dev/null 287 grep -h "^${x}" configure.{ac,in} 2>/dev/null
291 done 288 done
292 } 289 }
303 # Support running additional tools like gnome-autogen.sh. 300 # Support running additional tools like gnome-autogen.sh.
304 # Note: you need to add additional depends to the ebuild. 301 # Note: you need to add additional depends to the ebuild.
305 302
306 # gettext 303 # gettext
307 if [[ $(autotools_check_macro AM_GLIB_GNU_GETTEXT) ]]; then 304 if [[ $(autotools_check_macro AM_GLIB_GNU_GETTEXT) ]]; then
308 echo 'no' | autotools_run_tool glib-gettextize --copy 305 echo 'no' | autotools_run_tool glib-gettextize --copy --force
309 elif [[ $(autotools_check_macro AM_GNU_GETTEXT) ]]; then 306 elif [[ $(autotools_check_macro AM_GNU_GETTEXT) ]]; then
310 eautopoint --force 307 eautopoint --force
311 fi 308 fi
312 309
313 # intltool 310 # intltool
324 # gnome-doc 321 # gnome-doc
325 if [[ $(autotools_check_macro GNOME_DOC_INIT) ]]; then 322 if [[ $(autotools_check_macro GNOME_DOC_INIT) ]]; then
326 autotools_run_tool gnome-doc-prepare --copy --force 323 autotools_run_tool gnome-doc-prepare --copy --force
327 fi 324 fi
328 325
329 # We need to perform the check twice to know whether to run eaclocal.
330 # (_elibtoolize does that itself)
331 if [[ $(autotools_check_macro AC_PROG_LIBTOOL AM_PROG_LIBTOOL LT_INIT) ]] 326 if [[ $(autotools_check_macro AC_PROG_LIBTOOL AM_PROG_LIBTOOL LT_INIT) ]]
332 then 327 then
333 _elibtoolize --copy --force --install 328 _elibtoolize --copy --force --install
334 else 329 fi
330
335 eaclocal 331 eaclocal
336 fi
337
338 eautoconf 332 eautoconf
339 eautoheader 333 eautoheader
340 FROM_EAUTORECONF=sure eautomake 334 FROM_EAUTORECONF=sure eautomake
341 335
342 local x 336 local x
343 for x in $(autotools_get_subdirs); do 337 for x in $(autotools_check_macro_val AC_CONFIG_SUBDIRS); do
344 if [[ -d ${x} ]] ; then 338 if [[ -d ${x} ]] ; then
345 pushd "${x}" >/dev/null 339 pushd "${x}" >/dev/null || die
346 autotools-utils_eautoreconf 340 autotools-utils_autoreconf
347 popd >/dev/null 341 popd >/dev/null || die
348 fi 342 fi
349 done 343 done
350} 344}
351 345
352# @FUNCTION: autotools-utils_src_prepare 346# @FUNCTION: autotools-utils_src_prepare
357autotools-utils_src_prepare() { 351autotools-utils_src_prepare() {
358 debug-print-function ${FUNCNAME} "$@" 352 debug-print-function ${FUNCNAME} "$@"
359 353
360 local want_autoreconf=${AUTOTOOLS_AUTORECONF} 354 local want_autoreconf=${AUTOTOOLS_AUTORECONF}
361 355
362 touch "${T}"/.autotools-utils.timestamp || die
363 [[ ${PATCHES} ]] && epatch "${PATCHES[@]}" 356 [[ ${PATCHES} ]] && epatch "${PATCHES[@]}"
357
358 at_checksum() {
359 find '(' -name 'Makefile.am' \
360 -o -name 'configure.ac' \
361 -o -name 'configure.in' ')' \
362 -exec cksum {} + | sort -k2
363 }
364
365 [[ ! ${want_autoreconf} ]] && local checksum=$(at_checksum)
364 epatch_user 366 epatch_user
365 if [[ ! ${want_autoreconf} ]]; then 367 if [[ ! ${want_autoreconf} ]]; then
366 if [[ $(find . -newer "${T}"/.autotools-utils.timestamp \ 368 if [[ ${checksum} != $(at_checksum) ]]; then
367 -a '(' -name 'Makefile.am' \
368 -o -name 'configure.ac' \
369 -o -name 'configure.in' ')' \
370 -print -quit) ]]; then
371 einfo 'Will autoreconfigure due to patches applied.' 369 einfo 'Will autoreconfigure due to user patches applied.'
372 want_autoreconf=yep 370 want_autoreconf=yep
373 fi 371 fi
374 fi 372 fi
375 373
376 [[ ${want_autoreconf} ]] && autotools-utils_autoreconf 374 [[ ${want_autoreconf} ]] && eautoreconf
377 elibtoolize --patch-only 375 elibtoolize --patch-only
378} 376}
379 377
380# @FUNCTION: autotools-utils_src_configure 378# @FUNCTION: autotools-utils_src_configure
381# @DESCRIPTION: 379# @DESCRIPTION:
393 || die 'autotools-utils.eclass: myeconfargs has to be an array.' 391 || die 'autotools-utils.eclass: myeconfargs has to be an array.'
394 392
395 [[ ${EAPI} == 2 ]] && ! use prefix && EPREFIX= 393 [[ ${EAPI} == 2 ]] && ! use prefix && EPREFIX=
396 394
397 # Common args 395 # Common args
398 local econfargs=( 396 local econfargs=()
397
398 _check_build_dir
399 if "${ECONF_SOURCE}"/configure --help 2>&1 | grep -q '^ *--docdir='; then
400 econfargs+=(
399 --docdir="${EPREFIX}/usr/share/doc/${PF}" 401 --docdir="${EPREFIX}"/usr/share/doc/${PF}
400 ) 402 )
403 fi
401 404
402 # Handle static-libs found in IUSE, disable them by default 405 # Handle static-libs found in IUSE, disable them by default
403 if in_iuse static-libs; then 406 if in_iuse static-libs; then
404 econfargs+=( 407 econfargs+=(
405 --enable-shared 408 --enable-shared
408 fi 411 fi
409 412
410 # Append user args 413 # Append user args
411 econfargs+=("${myeconfargs[@]}") 414 econfargs+=("${myeconfargs[@]}")
412 415
413 _check_build_dir
414 mkdir -p "${AUTOTOOLS_BUILD_DIR}" || die "mkdir '${AUTOTOOLS_BUILD_DIR}' failed" 416 mkdir -p "${AUTOTOOLS_BUILD_DIR}" || die "mkdir '${AUTOTOOLS_BUILD_DIR}' failed"
415 pushd "${AUTOTOOLS_BUILD_DIR}" > /dev/null 417 pushd "${AUTOTOOLS_BUILD_DIR}" > /dev/null || die
416 econf "${econfargs[@]}" "$@" 418 econf "${econfargs[@]}" "$@"
417 popd > /dev/null 419 popd > /dev/null || die
418} 420}
419 421
420# @FUNCTION: autotools-utils_src_compile 422# @FUNCTION: autotools-utils_src_compile
421# @DESCRIPTION: 423# @DESCRIPTION:
422# The autotools src_compile function, invokes emake in specified AUTOTOOLS_BUILD_DIR. 424# The autotools src_compile function, invokes emake in specified AUTOTOOLS_BUILD_DIR.
423autotools-utils_src_compile() { 425autotools-utils_src_compile() {
424 debug-print-function ${FUNCNAME} "$@" 426 debug-print-function ${FUNCNAME} "$@"
425 427
426 _check_build_dir 428 _check_build_dir
427 pushd "${AUTOTOOLS_BUILD_DIR}" > /dev/null 429 pushd "${AUTOTOOLS_BUILD_DIR}" > /dev/null || die
428 emake "$@" || die 'emake failed' 430 emake "$@" || die 'emake failed'
429 popd > /dev/null 431 popd > /dev/null || die
430} 432}
431 433
432# @FUNCTION: autotools-utils_src_install 434# @FUNCTION: autotools-utils_src_install
433# @DESCRIPTION: 435# @DESCRIPTION:
434# The autotools src_install function. Runs emake install, unconditionally 436# The autotools src_install function. Runs emake install, unconditionally
439# DOCS and HTML_DOCS arrays are supported. See base.eclass(5) for reference. 441# DOCS and HTML_DOCS arrays are supported. See base.eclass(5) for reference.
440autotools-utils_src_install() { 442autotools-utils_src_install() {
441 debug-print-function ${FUNCNAME} "$@" 443 debug-print-function ${FUNCNAME} "$@"
442 444
443 _check_build_dir 445 _check_build_dir
444 pushd "${AUTOTOOLS_BUILD_DIR}" > /dev/null 446 pushd "${AUTOTOOLS_BUILD_DIR}" > /dev/null || die
445 emake DESTDIR="${D}" "$@" install || die "emake install failed" 447 emake DESTDIR="${D}" "$@" install || die "emake install failed"
446 popd > /dev/null 448 popd > /dev/null || die
447 449
448 # Move docs installed by autotools (in EAPI < 4). 450 # Move docs installed by autotools (in EAPI < 4).
449 if [[ ${EAPI} == [23] && -d ${D}${EPREFIX}/usr/share/doc/${PF} ]]; then 451 if [[ ${EAPI} == [23] ]] \
452 && path_exists "${D}${EPREFIX}"/usr/share/doc/${PF}/*; then
453 if [[ $(find "${D}${EPREFIX}"/usr/share/doc/${PF}/* -type d) ]]; then
454 eqawarn "autotools-utils: directories in docdir require at least EAPI 4"
455 else
450 mkdir "${T}"/temp-docdir 456 mkdir "${T}"/temp-docdir
451 mv "${D}${EPREFIX}"/usr/share/doc/${PF}/* "${T}"/temp-docdir/ \ 457 mv "${D}${EPREFIX}"/usr/share/doc/${PF}/* "${T}"/temp-docdir/ \
452 || die "moving docs to tempdir failed" 458 || die "moving docs to tempdir failed"
453 459
454 local f
455 for f in "${T}"/temp-docdir/*; do
456 [[ -d ${f} ]] \
457 && die "directories in docdir require at least EAPI 4"
458 done
459
460 dodoc "${T}"/temp-docdir/* || die "docdir dodoc failed" 460 dodoc "${T}"/temp-docdir/* || die "docdir dodoc failed"
461 rm -r "${T}"/temp-docdir || die 461 rm -r "${T}"/temp-docdir || die
462 fi
462 fi 463 fi
463 464
464 # XXX: support installing them from builddir as well? 465 # XXX: support installing them from builddir as well?
465 if [[ ${DOCS} ]]; then 466 if [[ ${DOCS} ]]; then
466 dodoc "${DOCS[@]}" || die "dodoc failed" 467 dodoc "${DOCS[@]}" || die "dodoc failed"
477 if [[ ${HTML_DOCS} ]]; then 478 if [[ ${HTML_DOCS} ]]; then
478 dohtml -r "${HTML_DOCS[@]}" || die "dohtml failed" 479 dohtml -r "${HTML_DOCS[@]}" || die "dohtml failed"
479 fi 480 fi
480 481
481 # Remove libtool files and unnecessary static libs 482 # Remove libtool files and unnecessary static libs
482 remove_libtool_files 483 prune_libtool_files
483} 484}
484 485
485# @FUNCTION: autotools-utils_src_test 486# @FUNCTION: autotools-utils_src_test
486# @DESCRIPTION: 487# @DESCRIPTION:
487# The autotools src_test function. Runs emake check in build directory. 488# The autotools src_test function. Runs emake check in build directory.
488autotools-utils_src_test() { 489autotools-utils_src_test() {
489 debug-print-function ${FUNCNAME} "$@" 490 debug-print-function ${FUNCNAME} "$@"
490 491
491 _check_build_dir 492 _check_build_dir
492 pushd "${AUTOTOOLS_BUILD_DIR}" > /dev/null 493 pushd "${AUTOTOOLS_BUILD_DIR}" > /dev/null || die
493 # Run default src_test as defined in ebuild.sh 494 # Run default src_test as defined in ebuild.sh
494 default_src_test 495 default_src_test
495 popd > /dev/null 496 popd > /dev/null || die
496} 497}

Legend:
Removed from v.1.38  
changed lines
  Added in v.1.56

  ViewVC Help
Powered by ViewVC 1.1.20