summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorWulf Krueger <philantrop@gentoo.org>2007-11-11 20:02:11 +0000
committerWulf Krueger <philantrop@gentoo.org>2007-11-11 20:02:11 +0000
commita617348b3325f4ad5e06a7f350fd2be92f66fcb1 (patch)
tree7381c28e80c71131b2ca85731e1c1977fdbc1704 /eclass/cmake-utils.eclass
parentmove find|touch to eclass (diff)
downloadgentoo-2-a617348b3325f4ad5e06a7f350fd2be92f66fcb1.tar.gz
gentoo-2-a617348b3325f4ad5e06a7f350fd2be92f66fcb1.tar.bz2
gentoo-2-a617348b3325f4ad5e06a7f350fd2be92f66fcb1.zip
Added a patch by Nelchael (use pushd/popd, allow use of CMAKE_IN_SOURCE_BUILD, define LIB_INSTALL_DIR) and cmake-utils_use_want by Ingmar to allow usage of the eclass by applications that need -DWANT_blah.
Diffstat (limited to 'eclass/cmake-utils.eclass')
-rw-r--r--eclass/cmake-utils.eclass40
1 files changed, 31 insertions, 9 deletions
diff --git a/eclass/cmake-utils.eclass b/eclass/cmake-utils.eclass
index b9817901ab4e..dc17857a5473 100644
--- a/eclass/cmake-utils.eclass
+++ b/eclass/cmake-utils.eclass
@@ -1,6 +1,6 @@
# Copyright 1999-2007 Gentoo Foundation
# Distributed under the terms of the GNU General Public License v2
-# $Header: /var/cvsroot/gentoo-x86/eclass/cmake-utils.eclass,v 1.1 2007/11/04 13:17:35 philantrop Exp $
+# $Header: /var/cvsroot/gentoo-x86/eclass/cmake-utils.eclass,v 1.2 2007/11/11 20:02:11 philantrop Exp $
# @ECLASS: cmake-utils.eclass
# @MAINTAINER:
@@ -42,6 +42,12 @@ cmake-utils_use_with() { _use_me_now WITH "$@" ; }
# Based on use_enable. See ebuild.sh
cmake-utils_use_enable() { _use_me_now ENABLE "$@" ; }
+# @FUNCTION: cmake-utils_use_want
+# @USAGE: <USE flag> [flag name]
+# @DESCRIPTION:
+# Based on use_enable. See ebuild.sh
+cmake-utils_use_want() { _use_me_now WANT "$@" ; }
+
# @FUNCTION: cmake-utils_src_compile
# @DESCRIPTION:
# General function for compiling with cmake. Default behaviour is to start an
@@ -49,7 +55,11 @@ cmake-utils_use_enable() { _use_me_now ENABLE "$@" ; }
cmake-utils_src_compile() {
debug-print-function $FUNCNAME $*
- cmake-utils_src_configureout
+ if [[ -n "${CMAKE_IN_SOURCE_BUILD}" ]]; then
+ cmake-utils_src_configurein
+ else
+ cmake-utils_src_configureout
+ fi
cmake-utils_src_make
}
@@ -74,11 +84,13 @@ cmake-utils_src_configureout() {
debug-print-function $FUNCNAME $*
local cmakeargs="${mycmakeargs} $(_common_configure_code)"
- mkdir "${WORKDIR}"/${PN}_build
- cd "${WORKDIR}"/${PN}_build
+ mkdir -p "${WORKDIR}"/${PN}_build
+ pushd "${WORKDIR}"/${PN}_build > /dev/null
debug-print "$LINENO $ECLASS $FUNCNAME: mycmakeargs is $cmakeargs"
cmake ${cmakeargs} "${S}" || die "Cmake failed"
+
+ popd > /dev/null
}
# Internal use only. Common configuration options for all types of builds.
@@ -91,6 +103,7 @@ _common_configure_code() {
echo -DCMAKE_CXX_COMPILER=$(type -P $(tc-getCXX))
echo -DCMAKE_INSTALL_PREFIX=${PREFIX:-/usr}
echo -DLIB_SUFFIX=${tmp_libdir/lib}
+ echo -DLIB_INSTALL_DIR=${PREFIX:-/usr}/${tmp_libdir}
[[ -n ${CMAKE_NO_COLOR} ]] && echo -DCMAKE_COLOR_MAKEFILE=OFF
}
@@ -103,12 +116,15 @@ cmake-utils_src_make() {
# At this point we can automatically check if it's an out-of-source or an
# in-source build
if [[ -d ${WORKDIR}/${PN}_build ]]; then
- cd "${WORKDIR}"/${PN}_build;
+ pushd "${WORKDIR}"/${PN}_build > /dev/null
fi
if ! [[ -z ${CMAKE_COMPILER_VERBOSE} ]]; then
- emake VERBOSE=1 || die "Make failed!";
+ emake VERBOSE=1 || die "Make failed!"
else
- emake || die "Make failed!";
+ emake || die "Make failed!"
+ fi
+ if [[ -d ${WORKDIR}/${PN}_build ]]; then
+ popd > /dev/null
fi
}
@@ -121,9 +137,12 @@ cmake-utils_src_install() {
# At this point we can automatically check if it's an out-of-source or an
# in-source build
if [[ -d ${WORKDIR}/${PN}_build ]]; then
- cd "${WORKDIR}"/${PN}_build;
+ pushd "${WORKDIR}"/${PN}_build > /dev/null
fi
emake install DESTDIR="${D}" || die "Make install failed"
+ if [[ -d ${WORKDIR}/${PN}_build ]]; then
+ popd > /dev/null
+ fi
}
# @FUNCTION: cmake-utils_src_test
@@ -135,7 +154,7 @@ cmake-utils_src_test() {
# At this point we can automatically check if it's an out-of-source or an
# in-source build
if [[ -d ${WORKDIR}/${PN}_build ]]; then
- cd "${WORKDIR}"/${PN}_build
+ pushd "${WORKDIR}"/${PN}_build > /dev/null
fi
# Standard implementation of src_test
if emake -j1 check -n &> /dev/null; then
@@ -151,4 +170,7 @@ cmake-utils_src_test() {
else
einfo ">>> Test phase [none]: ${CATEGORY}/${PF}"
fi
+ if [[ -d ${WORKDIR}/${PN}_build ]]; then
+ popd > /dev/null
+ fi
}