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

Diff of /eclass/cmake-utils.eclass

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

Revision 1.90 Revision 1.103
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/cmake-utils.eclass,v 1.90 2012/12/08 15:58:47 kensington Exp $ 3# $Header: /var/cvsroot/gentoo-x86/eclass/cmake-utils.eclass,v 1.103 2014/02/08 01:42:44 vapier Exp $
4 4
5# @ECLASS: cmake-utils.eclass 5# @ECLASS: cmake-utils.eclass
6# @MAINTAINER: 6# @MAINTAINER:
7# kde@gentoo.org 7# kde@gentoo.org
8# @AUTHOR: 8# @AUTHOR:
10# Maciej Mrozowski <reavertm@gentoo.org> 10# Maciej Mrozowski <reavertm@gentoo.org>
11# (undisclosed contributors) 11# (undisclosed contributors)
12# Original author: Zephyrus (zephyrus@mirach.it) 12# Original author: Zephyrus (zephyrus@mirach.it)
13# @BLURB: common ebuild functions for cmake-based packages 13# @BLURB: common ebuild functions for cmake-based packages
14# @DESCRIPTION: 14# @DESCRIPTION:
15# The cmake-utils eclass is base.eclass(5) wrapper that makes creating ebuilds for 15# The cmake-utils eclass makes creating ebuilds for cmake-based packages much easier.
16# cmake-based packages much easier.
17# It provides all inherited features (DOCS, HTML_DOCS, PATCHES) along with out-of-source 16# It provides all inherited features (DOCS, HTML_DOCS, PATCHES) along with out-of-source
18# builds (default), in-source builds and an implementation of the well-known use_enable 17# builds (default), in-source builds and an implementation of the well-known use_enable
19# and use_with functions for CMake. 18# and use_with functions for CMake.
19
20if [[ ${___ECLASS_ONCE_CMAKE_UTILS} != "recur -_+^+_- spank" ]] ; then
21___ECLASS_ONCE_CMAKE_UTILS="recur -_+^+_- spank"
20 22
21# @ECLASS-VARIABLE: WANT_CMAKE 23# @ECLASS-VARIABLE: WANT_CMAKE
22# @DESCRIPTION: 24# @DESCRIPTION:
23# Specify if cmake-utils eclass should depend on cmake optionaly or not. 25# Specify if cmake-utils eclass should depend on cmake optionaly or not.
24# This is usefull when only part of aplication is using cmake build system. 26# This is usefull when only part of aplication is using cmake build system.
26# used for optionality) 28# used for optionality)
27WANT_CMAKE="${WANT_CMAKE:-always}" 29WANT_CMAKE="${WANT_CMAKE:-always}"
28 30
29# @ECLASS-VARIABLE: CMAKE_MIN_VERSION 31# @ECLASS-VARIABLE: CMAKE_MIN_VERSION
30# @DESCRIPTION: 32# @DESCRIPTION:
31# Specify the minimum required CMake version. Default is 2.8.4 33# Specify the minimum required CMake version.
32CMAKE_MIN_VERSION="${CMAKE_MIN_VERSION:-2.8.4}" 34CMAKE_MIN_VERSION="${CMAKE_MIN_VERSION:-2.8.9}"
33 35
34# @ECLASS-VARIABLE: CMAKE_REMOVE_MODULES_LIST 36# @ECLASS-VARIABLE: CMAKE_REMOVE_MODULES_LIST
35# @DESCRIPTION: 37# @DESCRIPTION:
36# Space-separated list of CMake modules that will be removed in $S during src_prepare, 38# Space-separated list of CMake modules that will be removed in $S during src_prepare,
37# in order to force packages to use the system version. 39# in order to force packages to use the system version.
42# Do we want to remove anything? yes or whatever else for no 44# Do we want to remove anything? yes or whatever else for no
43CMAKE_REMOVE_MODULES="${CMAKE_REMOVE_MODULES:-yes}" 45CMAKE_REMOVE_MODULES="${CMAKE_REMOVE_MODULES:-yes}"
44 46
45# @ECLASS-VARIABLE: CMAKE_MAKEFILE_GENERATOR 47# @ECLASS-VARIABLE: CMAKE_MAKEFILE_GENERATOR
46# @DESCRIPTION: 48# @DESCRIPTION:
47# Specify a makefile generator to be used by cmake. At this point only "make" 49# Specify a makefile generator to be used by cmake.
48# and "ninja" is supported. 50# At this point only "emake" and "ninja" are supported.
49CMAKE_MAKEFILE_GENERATOR="${CMAKE_MAKEFILE_GENERATOR:-make}" 51CMAKE_MAKEFILE_GENERATOR="${CMAKE_MAKEFILE_GENERATOR:-emake}"
52
53# @ECLASS-VARIABLE: CMAKE_WARN_UNUSED_CLI
54# @DESCRIPTION:
55# Warn about variables that are declared on the command line
56# but not used. Might give false-positives.
57# "no" to disable (default) or anything else to enable.
58CMAKE_WARN_UNUSED_CLI="${CMAKE_WARN_UNUSED_CLI:-no}"
50 59
51CMAKEDEPEND="" 60CMAKEDEPEND=""
52case ${WANT_CMAKE} in 61case ${WANT_CMAKE} in
53 always) 62 always)
54 ;; 63 ;;
55 *) 64 *)
56 IUSE+=" ${WANT_CMAKE}" 65 IUSE+=" ${WANT_CMAKE}"
57 CMAKEDEPEND+="${WANT_CMAKE}? ( " 66 CMAKEDEPEND+="${WANT_CMAKE}? ( "
58 ;; 67 ;;
59esac 68esac
60inherit toolchain-funcs multilib flag-o-matic base 69inherit toolchain-funcs multilib flag-o-matic eutils
61 70
62CMAKE_EXPF="src_compile src_test src_install" 71CMAKE_EXPF="src_compile src_test src_install"
63case ${EAPI:-0} in 72case ${EAPI:-0} in
64 2|3|4|5) CMAKE_EXPF+=" src_configure" ;; 73 2|3|4|5) CMAKE_EXPF+=" src_prepare src_configure" ;;
65 1|0) ;; 74 1|0) eerror "cmake-utils no longer supports EAPI 0-1." && die
75 ;;
66 *) die "Unknown EAPI, Bug eclass maintainers." ;; 76 *) die "Unknown EAPI, bug eclass maintainers." ;;
67esac 77esac
68EXPORT_FUNCTIONS ${CMAKE_EXPF} 78EXPORT_FUNCTIONS ${CMAKE_EXPF}
79
80case ${CMAKE_MAKEFILE_GENERATOR} in
81 emake)
82 CMAKEDEPEND+=" sys-devel/make"
83 ;;
84 ninja)
85 CMAKEDEPEND+=" dev-util/ninja"
86 ;;
87 *)
88 eerror "Unknown value for \${CMAKE_MAKEFILE_GENERATOR}"
89 die "Value ${CMAKE_MAKEFILE_GENERATOR} is not supported"
90 ;;
91esac
69 92
70if [[ ${PN} != cmake ]]; then 93if [[ ${PN} != cmake ]]; then
71 CMAKEDEPEND+=" >=dev-util/cmake-${CMAKE_MIN_VERSION}" 94 CMAKEDEPEND+=" >=dev-util/cmake-${CMAKE_MIN_VERSION}"
72fi 95fi
73 96
193 echo ">>> Working in BUILD_DIR: \"$BUILD_DIR\"" 216 echo ">>> Working in BUILD_DIR: \"$BUILD_DIR\""
194} 217}
195 218
196# Determine which generator to use 219# Determine which generator to use
197_generator_to_use() { 220_generator_to_use() {
198 if [[ ${CMAKE_MAKEFILE_GENERATOR} = "ninja" ]]; then 221 local generator_name
199 has_version dev-util/ninja && echo "Ninja" && return 222
200 fi 223 case ${CMAKE_MAKEFILE_GENERATOR} in
201 echo "Unix Makefiles" 224 ninja)
225 generator_name="Ninja"
226 ;;
227 emake)
228 generator_name="Unix Makefiles"
229 ;;
230 *)
231 eerror "Unknown value for \${CMAKE_MAKEFILE_GENERATOR}"
232 die "Value ${CMAKE_MAKEFILE_GENERATOR} is not supported"
233 ;;
234 esac
235
236 echo ${generator_name}
202} 237}
203 238
204# @FUNCTION: cmake-utils_use_with 239# @FUNCTION: cmake-utils_use_with
205# @USAGE: <USE flag> [flag name] 240# @USAGE: <USE flag> [flag name]
206# @DESCRIPTION: 241# @DESCRIPTION:
217# 252#
218# `cmake-utils_use_enable foo FOO` echoes -DENABLE_FOO=ON if foo is enabled 253# `cmake-utils_use_enable foo FOO` echoes -DENABLE_FOO=ON if foo is enabled
219# and -DENABLE_FOO=OFF if it is disabled. 254# and -DENABLE_FOO=OFF if it is disabled.
220cmake-utils_use_enable() { _use_me_now ENABLE_ "$@" ; } 255cmake-utils_use_enable() { _use_me_now ENABLE_ "$@" ; }
221 256
257# @FUNCTION: cmake-utils_use_find_package
258# @USAGE: <USE flag> [flag name]
259# @DESCRIPTION:
260# Based on use_enable. See ebuild(5).
261#
262# `cmake-utils_use_find_package foo LibFoo` echoes -DCMAKE_DISABLE_FIND_PACKAGE_LibFoo=OFF
263# if foo is enabled and -DCMAKE_DISABLE_FIND_PACKAGE_LibFoo=ON if it is disabled.
264# This can be used to make find_package optional (since cmake-2.8.6).
265cmake-utils_use_find_package() { _use_me_now_inverted CMAKE_DISABLE_FIND_PACKAGE_ "$@" ; }
266
222# @FUNCTION: cmake-utils_use_disable 267# @FUNCTION: cmake-utils_use_disable
223# @USAGE: <USE flag> [flag name] 268# @USAGE: <USE flag> [flag name]
224# @DESCRIPTION: 269# @DESCRIPTION:
225# Based on inversion of use_enable. See ebuild(5). 270# Based on inversion of use_enable. See ebuild(5).
226# 271#
279# Based on use_enable. See ebuild(5). 324# Based on use_enable. See ebuild(5).
280# 325#
281# `cmake-utils_use foo FOO` echoes -DFOO=ON if foo is enabled 326# `cmake-utils_use foo FOO` echoes -DFOO=ON if foo is enabled
282# and -DFOO=OFF if it is disabled. 327# and -DFOO=OFF if it is disabled.
283cmake-utils_use() { _use_me_now "" "$@" ; } 328cmake-utils_use() { _use_me_now "" "$@" ; }
329
330# @FUNCTION: cmake-utils_useno
331# @USAGE: <USE flag> [flag name]
332# @DESCRIPTION:
333# Based on use_enable. See ebuild(5).
334#
335# `cmake-utils_useno foo NOFOO` echoes -DNOFOO=OFF if foo is enabled
336# and -DNOFOO=ON if it is disabled.
337cmake-utils_useno() { _use_me_now_inverted "" "$@" ; }
284 338
285# Internal function for modifying hardcoded definitions. 339# Internal function for modifying hardcoded definitions.
286# Removes dangerous definitions that override Gentoo settings. 340# Removes dangerous definitions that override Gentoo settings.
287_modify-cmakelists() { 341_modify-cmakelists() {
288 debug-print-function ${FUNCNAME} "$@" 342 debug-print-function ${FUNCNAME} "$@"
313 Module \${CMAKE_MODULE_LINKER_FLAGS} 367 Module \${CMAKE_MODULE_LINKER_FLAGS}
314 Shared \${CMAKE_SHARED_LINKER_FLAGS}\n") 368 Shared \${CMAKE_SHARED_LINKER_FLAGS}\n")
315 _EOF_ 369 _EOF_
316} 370}
317 371
372enable_cmake-utils_src_prepare() {
373 debug-print-function ${FUNCNAME} "$@"
374
375 debug-print "$FUNCNAME: PATCHES=$PATCHES"
376
377 pushd "${S}" >/dev/null
378 [[ ${PATCHES[@]} ]] && epatch "${PATCHES[@]}"
379
380 debug-print "$FUNCNAME: applying user patches"
381 epatch_user
382
383 popd >/dev/null
384}
385
386# @VARIABLE: mycmakeargs
387# @DEFAULT_UNSET
388# @DESCRIPTION:
389# Optional cmake defines as a bash array. Should be defined before calling
390# src_configure.
391# @CODE
392# src_configure() {
393# local mycmakeargs=(
394# $(cmake-utils_use_with openconnect)
395# )
396# cmake-utils_src_configure
397# }
398
399
318enable_cmake-utils_src_configure() { 400enable_cmake-utils_src_configure() {
319 debug-print-function ${FUNCNAME} "$@" 401 debug-print-function ${FUNCNAME} "$@"
320 402
321 [[ "${CMAKE_REMOVE_MODULES}" == "yes" ]] && { 403 [[ "${CMAKE_REMOVE_MODULES}" == "yes" ]] && {
322 local name 404 local name
357 SET (CMAKE_C_COMPILER $(type -P $(tc-getCC)) CACHE FILEPATH "C compiler" FORCE) 439 SET (CMAKE_C_COMPILER $(type -P $(tc-getCC)) CACHE FILEPATH "C compiler" FORCE)
358 SET (CMAKE_C_COMPILE_OBJECT "<CMAKE_C_COMPILER> <DEFINES> ${CPPFLAGS} <FLAGS> -o <OBJECT> -c <SOURCE>" CACHE STRING "C compile command" FORCE) 440 SET (CMAKE_C_COMPILE_OBJECT "<CMAKE_C_COMPILER> <DEFINES> ${CPPFLAGS} <FLAGS> -o <OBJECT> -c <SOURCE>" CACHE STRING "C compile command" FORCE)
359 SET (CMAKE_CXX_COMPILER $(type -P $(tc-getCXX)) CACHE FILEPATH "C++ compiler" FORCE) 441 SET (CMAKE_CXX_COMPILER $(type -P $(tc-getCXX)) CACHE FILEPATH "C++ compiler" FORCE)
360 SET (CMAKE_CXX_COMPILE_OBJECT "<CMAKE_CXX_COMPILER> <DEFINES> ${CPPFLAGS} <FLAGS> -o <OBJECT> -c <SOURCE>" CACHE STRING "C++ compile command" FORCE) 442 SET (CMAKE_CXX_COMPILE_OBJECT "<CMAKE_CXX_COMPILER> <DEFINES> ${CPPFLAGS} <FLAGS> -o <OBJECT> -c <SOURCE>" CACHE STRING "C++ compile command" FORCE)
361 SET (CMAKE_RANLIB $(type -P $(tc-getRANLIB)) CACHE FILEPATH "Archive index generator" FORCE) 443 SET (CMAKE_RANLIB $(type -P $(tc-getRANLIB)) CACHE FILEPATH "Archive index generator" FORCE)
444 SET (PKG_CONFIG_EXECUTABLE $(type -P $(tc-getPKG_CONFIG)) CACHE FILEPATH "pkg-config executable" FORCE)
362 _EOF_ 445 _EOF_
363 446
364 has "${EAPI:-0}" 0 1 2 && ! use prefix && EPREFIX= 447 has "${EAPI:-0}" 0 1 2 && ! use prefix && EPREFIX=
365 448
366 if [[ ${EPREFIX} ]]; then 449 if [[ ${EPREFIX} ]]; then
402 local mycmakeargs_local=(${mycmakeargs}) 485 local mycmakeargs_local=(${mycmakeargs})
403 else 486 else
404 local mycmakeargs_local=("${mycmakeargs[@]}") 487 local mycmakeargs_local=("${mycmakeargs[@]}")
405 fi 488 fi
406 489
490 if [[ ${CMAKE_WARN_UNUSED_CLI} == no ]] ; then
491 local warn_unused_cli="--no-warn-unused-cli"
492 else
493 local warn_unused_cli=""
494 fi
495
407 # Common configure parameters (overridable) 496 # Common configure parameters (overridable)
408 # NOTE CMAKE_BUILD_TYPE can be only overriden via CMAKE_BUILD_TYPE eclass variable 497 # NOTE CMAKE_BUILD_TYPE can be only overriden via CMAKE_BUILD_TYPE eclass variable
409 # No -DCMAKE_BUILD_TYPE=xxx definitions will be in effect. 498 # No -DCMAKE_BUILD_TYPE=xxx definitions will be in effect.
410 local cmakeargs=( 499 local cmakeargs=(
411 --no-warn-unused-cli 500 ${warn_unused_cli}
412 -C "${common_config}" 501 -C "${common_config}"
413 -G "$(_generator_to_use)" 502 -G "$(_generator_to_use)"
414 -DCMAKE_INSTALL_PREFIX="${EPREFIX}${PREFIX}" 503 -DCMAKE_INSTALL_PREFIX="${EPREFIX}${PREFIX}"
415 "${mycmakeargs_local[@]}" 504 "${mycmakeargs_local[@]}"
416 -DCMAKE_BUILD_TYPE="${CMAKE_BUILD_TYPE}" 505 -DCMAKE_BUILD_TYPE="${CMAKE_BUILD_TYPE}"
417 -DCMAKE_INSTALL_DO_STRIP=OFF 506 -DCMAKE_INSTALL_DO_STRIP=OFF
418 -DCMAKE_USER_MAKE_RULES_OVERRIDE="${build_rules}" 507 -DCMAKE_USER_MAKE_RULES_OVERRIDE="${build_rules}"
419 "${MYCMAKEARGS}" 508 "${MYCMAKEARGS}"
420 ) 509 )
421 510
422 pushd "${BUILD_DIR}" > /dev/null 511 pushd "${BUILD_DIR}" >/dev/null
423 debug-print "${LINENO} ${ECLASS} ${FUNCNAME}: mycmakeargs is ${mycmakeargs_local[*]}" 512 debug-print "${LINENO} ${ECLASS} ${FUNCNAME}: mycmakeargs is ${mycmakeargs_local[*]}"
424 echo "${CMAKE_BINARY}" "${cmakeargs[@]}" "${CMAKE_USE_DIR}" 513 echo "${CMAKE_BINARY}" "${cmakeargs[@]}" "${CMAKE_USE_DIR}"
425 "${CMAKE_BINARY}" "${cmakeargs[@]}" "${CMAKE_USE_DIR}" || die "cmake failed" 514 "${CMAKE_BINARY}" "${cmakeargs[@]}" "${CMAKE_USE_DIR}" || die "cmake failed"
426 popd > /dev/null 515 popd >/dev/null
427} 516}
428 517
429enable_cmake-utils_src_compile() { 518enable_cmake-utils_src_compile() {
430 debug-print-function ${FUNCNAME} "$@" 519 debug-print-function ${FUNCNAME} "$@"
431 520
432 has src_configure ${CMAKE_EXPF} || cmake-utils_src_configure 521 has src_configure ${CMAKE_EXPF} || cmake-utils_src_configure
433 cmake-utils_src_make "$@" 522 cmake-utils_src_make "$@"
523}
524
525_ninjaopts_from_makeopts() {
526 if [[ ${NINJAOPTS+set} == set ]]; then
527 return 0
528 fi
529 local ninjaopts=()
530 set -- ${MAKEOPTS}
531 while (( $# )); do
532 case $1 in
533 -j|-l|-k)
534 ninjaopts+=( $1 $2 )
535 shift 2
536 ;;
537 -j*|-l*|-k*)
538 ninjaopts+=( $1 )
539 shift 1
540 ;;
541 *) shift ;;
542 esac
543 done
544 export NINJAOPTS="${ninjaopts[*]}"
545}
546
547# @FUNCTION: ninja_src_make
548# @INTERNAL
549# @DESCRIPTION:
550# Build the package using ninja generator
551ninja_src_make() {
552 debug-print-function ${FUNCNAME} "$@"
553
554 [[ -e build.ninja ]] || die "build.ninja not found. Error during configure stage."
555
556 _ninjaopts_from_makeopts
557
558 if [[ "${CMAKE_VERBOSE}" != "OFF" ]]; then
559 set -- ninja ${NINJAOPTS} -v "$@"
560 else
561 set -- ninja ${NINJAOPTS} "$@"
562 fi
563
564 echo "$@"
565 "$@" || die
566}
567
568# @FUNCTION: emake_src_make
569# @INTERNAL
570# @DESCRIPTION:
571# Build the package using make generator
572emake_src_make() {
573 debug-print-function ${FUNCNAME} "$@"
574
575 [[ -e Makefile ]] || die "Makefile not found. Error during configure stage."
576
577 if [[ "${CMAKE_VERBOSE}" != "OFF" ]]; then
578 emake VERBOSE=1 "$@" || die
579 else
580 emake "$@" || die
581 fi
582
434} 583}
435 584
436# @FUNCTION: cmake-utils_src_make 585# @FUNCTION: cmake-utils_src_make
437# @DESCRIPTION: 586# @DESCRIPTION:
438# Function for building the package. Automatically detects the build type. 587# Function for building the package. Automatically detects the build type.
439# All arguments are passed to emake. 588# All arguments are passed to emake.
440cmake-utils_src_make() { 589cmake-utils_src_make() {
441 debug-print-function ${FUNCNAME} "$@" 590 debug-print-function ${FUNCNAME} "$@"
442 591
443 _check_build_dir 592 _check_build_dir
444 pushd "${BUILD_DIR}" > /dev/null 593 pushd "${BUILD_DIR}" >/dev/null
445 if [[ $(_generator_to_use) = Ninja ]]; then 594
446 # first check if Makefile exist otherwise die 595 ${CMAKE_MAKEFILE_GENERATOR}_src_make $@
447 [[ -e build.ninja ]] || die "Makefile not found. Error during configure stage." 596
448 if [[ "${CMAKE_VERBOSE}" != "OFF" ]]; then
449 #TODO get load average from portage (-l option)
450 ninja ${MAKEOPTS} -v "$@"
451 else
452 ninja "$@"
453 fi || die "ninja failed!"
454 else
455 # first check if Makefile exist otherwise die
456 [[ -e Makefile ]] || die "Makefile not found. Error during configure stage."
457 if [[ "${CMAKE_VERBOSE}" != "OFF" ]]; then
458 emake VERBOSE=1 "$@" || die "Make failed!"
459 else
460 emake "$@" || die "Make failed!"
461 fi
462 fi
463 popd > /dev/null 597 popd >/dev/null
464} 598}
465 599
466enable_cmake-utils_src_install() { 600enable_cmake-utils_src_install() {
467 debug-print-function ${FUNCNAME} "$@" 601 debug-print-function ${FUNCNAME} "$@"
468 602
469 _check_build_dir 603 _check_build_dir
470 pushd "${BUILD_DIR}" > /dev/null 604 pushd "${BUILD_DIR}" >/dev/null
471 if [[ $(_generator_to_use) = Ninja ]]; then 605 DESTDIR="${D}" ${CMAKE_MAKEFILE_GENERATOR} install "$@" || die "died running ${CMAKE_MAKEFILE_GENERATOR} install"
472 DESTDIR=${D} ninja install "$@" || die "died running ninja install"
473 base_src_install_docs
474 else
475 base_src_install "$@"
476 fi
477 popd > /dev/null 606 popd >/dev/null
607
608 pushd "${S}" >/dev/null
609 # Install docs, copied from base_src_install_docs
610 local x
611
612 if [[ "$(declare -p DOCS 2>/dev/null 2>&1)" == "declare -a"* ]]; then
613 for x in "${DOCS[@]}"; do
614 debug-print "$FUNCNAME: docs: creating document from ${x}"
615 dodoc "${x}" || die "dodoc failed"
616 done
617 fi
618 if [[ "$(declare -p HTML_DOCS 2>/dev/null 2>&1)" == "declare -a"* ]]; then
619 for x in "${HTML_DOCS[@]}"; do
620 debug-print "$FUNCNAME: docs: creating html document from ${x}"
621 dohtml -r "${x}" || die "dohtml failed"
622 done
623 fi
478 624
479 # Backward compatibility, for non-array variables 625 # Backward compatibility, for non-array variables
480 if [[ -n "${DOCS}" ]] && [[ "$(declare -p DOCS 2>/dev/null 2>&1)" != "declare -a"* ]]; then 626 if [[ -n "${DOCS}" ]] && [[ "$(declare -p DOCS 2>/dev/null 2>&1)" != "declare -a"* ]]; then
481 dodoc ${DOCS} || die "dodoc failed" 627 dodoc ${DOCS} || die "dodoc failed"
482 fi 628 fi
483 if [[ -n "${HTML_DOCS}" ]] && [[ "$(declare -p HTML_DOCS 2>/dev/null 2>&1)" != "declare -a"* ]]; then 629 if [[ -n "${HTML_DOCS}" ]] && [[ "$(declare -p HTML_DOCS 2>/dev/null 2>&1)" != "declare -a"* ]]; then
484 dohtml -r ${HTML_DOCS} || die "dohtml failed" 630 dohtml -r ${HTML_DOCS} || die "dohtml failed"
485 fi 631 fi
632
633 popd >/dev/null
486} 634}
487 635
488enable_cmake-utils_src_test() { 636enable_cmake-utils_src_test() {
489 debug-print-function ${FUNCNAME} "$@" 637 debug-print-function ${FUNCNAME} "$@"
490 638
491 _check_build_dir 639 _check_build_dir
492 pushd "${BUILD_DIR}" > /dev/null 640 pushd "${BUILD_DIR}" >/dev/null
493 [[ -e CTestTestfile.cmake ]] || { echo "No tests found. Skipping."; return 0 ; } 641 [[ -e CTestTestfile.cmake ]] || { echo "No tests found. Skipping."; return 0 ; }
494 642
495 [[ -n ${TEST_VERBOSE} ]] && myctestargs+=( --extra-verbose --output-on-failure ) 643 [[ -n ${TEST_VERBOSE} ]] && myctestargs+=( --extra-verbose --output-on-failure )
496 644
497 if ctest "${myctestargs[@]}" "$@" ; then 645 if ctest "${myctestargs[@]}" "$@" ; then
498 einfo "Tests succeeded." 646 einfo "Tests succeeded."
499 popd > /dev/null 647 popd >/dev/null
500 return 0 648 return 0
501 else 649 else
502 if [[ -n "${CMAKE_YES_I_WANT_TO_SEE_THE_TEST_LOG}" ]] ; then 650 if [[ -n "${CMAKE_YES_I_WANT_TO_SEE_THE_TEST_LOG}" ]] ; then
503 # on request from Diego 651 # on request from Diego
504 eerror "Tests failed. Test log ${BUILD_DIR}/Testing/Temporary/LastTest.log follows:" 652 eerror "Tests failed. Test log ${BUILD_DIR}/Testing/Temporary/LastTest.log follows:"
509 else 657 else
510 die "Tests failed. When you file a bug, please attach the following file: \n\t${BUILD_DIR}/Testing/Temporary/LastTest.log" 658 die "Tests failed. When you file a bug, please attach the following file: \n\t${BUILD_DIR}/Testing/Temporary/LastTest.log"
511 fi 659 fi
512 660
513 # die might not die due to nonfatal 661 # die might not die due to nonfatal
514 popd > /dev/null 662 popd >/dev/null
515 return 1 663 return 1
516 fi 664 fi
665}
666
667# @FUNCTION: cmake-utils_src_prepare
668# @DESCRIPTION:
669# Apply ebuild and user patches.
670cmake-utils_src_prepare() {
671 _execute_optionaly "src_prepare" "$@"
517} 672}
518 673
519# @FUNCTION: cmake-utils_src_configure 674# @FUNCTION: cmake-utils_src_configure
520# @DESCRIPTION: 675# @DESCRIPTION:
521# General function for configuring with cmake. Default behaviour is to start an 676# General function for configuring with cmake. Default behaviour is to start an
554 enable_cmake-utils_${phase} "$@" 709 enable_cmake-utils_${phase} "$@"
555 else 710 else
556 use ${WANT_CMAKE} && enable_cmake-utils_${phase} "$@" 711 use ${WANT_CMAKE} && enable_cmake-utils_${phase} "$@"
557 fi 712 fi
558} 713}
714
715fi

Legend:
Removed from v.1.90  
changed lines
  Added in v.1.103

  ViewVC Help
Powered by ViewVC 1.1.20