/[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.7 Revision 1.26
1# Copyright 1999-2007 Gentoo Foundation 1# Copyright 1999-2009 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.7 2008/03/29 21:33:17 philantrop Exp $ 3# $Header: /var/cvsroot/gentoo-x86/eclass/cmake-utils.eclass,v 1.26 2009/05/08 10:54:02 scarabeus 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#
9# @CODE
10# Tomáš Chvátal <scarabeus@gentoo.org>
11# Maciej Mrozowski <reavertm@poczta.fm>
12# (undisclosed contributors)
13# Original author: Zephyrus (zephyrus@mirach.it)
14# @CODE
8# @BLURB: common ebuild functions for cmake-based packages 15# @BLURB: common ebuild functions for cmake-based packages
9# @DESCRIPTION: 16# @DESCRIPTION:
10# The cmake-utils eclass contains functions that make creating ebuilds for 17# The cmake-utils eclass contains functions that make creating ebuilds for
11# cmake-based packages much easier. 18# cmake-based packages much easier.
12# Its main features are support of out-of-source builds as well as in-source 19# Its main features are support of out-of-source builds as well as in-source
13# builds and an implementation of the well-known use_enable and use_with 20# builds and an implementation of the well-known use_enable and use_with
14# functions for CMake. 21# functions for CMake.
15 22
16# Original author: Zephyrus (zephyrus@mirach.it)
17
18inherit toolchain-funcs multilib 23inherit toolchain-funcs multilib flag-o-matic base
19 24
25EXPF="src_compile src_test src_install"
26case ${EAPI:-0} in
27 2) EXPF="${EXPF} src_configure" ;;
28 1|0) ;;
29 *) die "Unknown EAPI, Bug eclass maintainers." ;;
30esac
31EXPORT_FUNCTIONS ${EXPF}
32
20DESCRIPTION="Based on the ${ECLASS} eclass" 33: ${DESCRIPTION:="Based on the ${ECLASS} eclass"}
21 34
22DEPEND="dev-util/cmake" 35if [[ ${PN} != cmake ]]; then
36 CMAKEDEPEND=">=dev-util/cmake-2.6.2-r1"
37fi
23 38
24EXPORT_FUNCTIONS src_compile src_test src_install 39DEPEND="${CMAKEDEPEND}
40 userland_GNU? ( >=sys-apps/findutils-4.4.0 )
41"
25 42
26# Internal function use by cmake-utils_use_with and cmake-utils_use_enable 43# Internal functions used by cmake-utils_use_*
27_use_me_now() { 44_use_me_now() {
28 debug-print-function $FUNCNAME $* 45 debug-print-function ${FUNCNAME} "$@"
46
47 local uper capitalised x
29 [[ -z $2 ]] && die "cmake-utils_use-$1 <USE flag> [<flag name>]" 48 [[ -z $2 ]] && die "cmake-utils_use-$1 <USE flag> [<flag name>]"
49 if [[ ! -z $3 ]]; then
50 # user specified the use name so use it
30 echo "-D$1_${3:-$2}=$(use $2 && echo ON || echo OFF)" 51 echo "-D$1$3=$(use $2 && echo ON || echo OFF)"
52 else
53 # use all various most used combinations
54 uper=$(echo ${2} | tr '[:lower:]' '[:upper:]')
55 capitalised=$(echo ${2} | sed 's/\<\(.\)\([^ ]*\)/\u\1\L\2/g')
56 for x in $2 $uper $capitalised; do
57 echo "-D$1$x=$(use $2 && echo ON || echo OFF) "
58 done
59 fi
31} 60}
61_use_me_now_inverted() {
62 debug-print-function ${FUNCNAME} "$@"
32 63
64 local uper capitalised x
65 [[ -z $2 ]] && die "cmake-utils_use-$1 <USE flag> [<flag name>]"
66 if [[ ! -z $3 ]]; then
67 # user specified the use name so use it
68 echo "-D$1$3=$(use $2 && echo OFF || echo ON)"
69 else
70 # use all various most used combinations
71 uper=$(echo ${2} | tr '[:lower:]' '[:upper:]')
72 capitalised=$(echo ${2} | sed 's/\<\(.\)\([^ ]*\)/\u\1\L\2/g')
73 for x in $2 $uper $capitalised; do
74 echo "-D$1$x=$(use $2 && echo OFF || echo ON) "
75 done
76 fi
77}
78
33# @VARIABLE: DOCS 79# @ECLASS-VARIABLE: DOCS
80# @DESCRIPTION:
81# Documents passed to dodoc command.
82
83# @ECLASS-VARIABLE: HTML_DOCS
84# @DESCRIPTION:
85# Documents passed to dohtml command.
86
87# @ECLASS-VARIABLE: PREFIX
88# @DESCRIPTION:
89# Eclass respects PREFIX variable, though it's not recommended way to set
90# install/lib/bin prefixes.
91# Use -DCMAKE_INSTALL_PREFIX=... CMake variable instead.
92
93# @ECLASS-VARIABLE: CMAKE_IN_SOURCE_BUILD
94# @DESCRIPTION:
95# Set to enable in-source build.
96
97# @ECLASS-VARIABLE: CMAKE_NO_COLOR
98# @DESCRIPTION:
99# Set to disable cmake output coloring.
100
101# @ECLASS-VARIABLE: CMAKE_VERBOSE
102# @DESCRIPTION:
103# Set to enable verbose messages during compilation.
104
105# @ECLASS-VARIABLE: CMAKE_BUILD_TYPE
106# @DESCRIPTION:
107# Set to override default CMAKE_BUILD_TYPE. Only useful for packages
108# known to make use of "if (CMAKE_BUILD_TYPE MATCHES xxx)".
109# If about to be set - needs to be set before invoking cmake-utils_src_configure.
110# You usualy do *NOT* want nor need to set it as it pulls CMake default build-type
111# specific compiler flags overriding make.conf.
112: ${CMAKE_BUILD_TYPE:=Gentoo}
113
114# @FUNCTION: _check_build_dir
115# @DESCRIPTION:
116# Determine using IN or OUT source build
117_check_build_dir() {
118 # @ECLASS-VARIABLE: CMAKE_USE_DIR
34# @DESCRIPTION: 119 # @DESCRIPTION:
35# Documents to dodoc 120 # Sets the directory where we are working with cmake.
121 # For example when application uses autotools and only one
122 # plugin needs to be done by cmake.
123 # By default it uses ${S}.
124 : ${CMAKE_USE_DIR:=${S}}
36 125
126 # in/out source build
127 if [[ -n "${CMAKE_IN_SOURCE_BUILD}" ]]; then
128 CMAKE_BUILD_DIR="${CMAKE_USE_DIR}"
129 else
130 CMAKE_BUILD_DIR="${CMAKE_USE_DIR}_build"
131 fi
132 echo ">>> Working in BUILD_DIR: \"$CMAKE_BUILD_DIR\""
133}
37# @FUNCTION: cmake-utils_use_with 134# @FUNCTION: cmake-utils_use_with
38# @USAGE: <USE flag> [flag name] 135# @USAGE: <USE flag> [flag name]
39# @DESCRIPTION: 136# @DESCRIPTION:
40# Based on use_with. See ebuild(5). 137# Based on use_with. See ebuild(5).
41# 138#
42# `cmake-utils_use_with foo FOO` echoes -DWITH_FOO=ON if foo is enabled 139# `cmake-utils_use_with foo FOO` echoes -DWITH_FOO=ON if foo is enabled
43# and -DWITH_FOO=OFF if it is disabled. 140# and -DWITH_FOO=OFF if it is disabled.
44cmake-utils_use_with() { _use_me_now WITH "$@" ; } 141cmake-utils_use_with() { _use_me_now WITH_ "$@" ; }
45 142
46# @FUNCTION: cmake-utils_use_enable 143# @FUNCTION: cmake-utils_use_enable
47# @USAGE: <USE flag> [flag name] 144# @USAGE: <USE flag> [flag name]
48# @DESCRIPTION: 145# @DESCRIPTION:
49# Based on use_enable. See ebuild(5). 146# Based on use_enable. See ebuild(5).
50# 147#
51# `cmake-utils_use_enable foo FOO` echoes -DENABLE_FOO=ON if foo is enabled 148# `cmake-utils_use_enable foo FOO` echoes -DENABLE_FOO=ON if foo is enabled
52# and -DENABLE_FOO=OFF if it is disabled. 149# and -DENABLE_FOO=OFF if it is disabled.
53cmake-utils_use_enable() { _use_me_now ENABLE "$@" ; } 150cmake-utils_use_enable() { _use_me_now ENABLE_ "$@" ; }
151
152# @FUNCTION: cmake-utils_use_disable
153# @USAGE: <USE flag> [flag name]
154# @DESCRIPTION:
155# Based on inversion of use_enable. See ebuild(5).
156#
157# `cmake-utils_use_enable foo FOO` echoes -DDISABLE_FOO=OFF if foo is enabled
158# and -DDISABLE_FOO=ON if it is disabled.
159cmake-utils_use_disable() { _use_me_now_inverted DISABLE_ "$@" ; }
160
161# @FUNCTION: cmake-utils_use_no
162# @USAGE: <USE flag> [flag name]
163# @DESCRIPTION:
164# Based on use_disable. See ebuild(5).
165#
166# `cmake-utils_use_no foo FOO` echoes -DNO_FOO=OFF if foo is enabled
167# and -DNO_FOO=ON if it is disabled.
168cmake-utils_use_no() { _use_me_now_inverted NO_ "$@" ; }
54 169
55# @FUNCTION: cmake-utils_use_want 170# @FUNCTION: cmake-utils_use_want
56# @USAGE: <USE flag> [flag name] 171# @USAGE: <USE flag> [flag name]
57# @DESCRIPTION: 172# @DESCRIPTION:
58# Based on use_enable. See ebuild(5). 173# Based on use_enable. See ebuild(5).
59# 174#
60# `cmake-utils_use_want foo FOO` echoes -DWANT_FOO=ON if foo is enabled 175# `cmake-utils_use_want foo FOO` echoes -DWANT_FOO=ON if foo is enabled
61# and -DWANT_FOO=OFF if it is disabled. 176# and -DWANT_FOO=OFF if it is disabled.
62cmake-utils_use_want() { _use_me_now WANT "$@" ; } 177cmake-utils_use_want() { _use_me_now WANT_ "$@" ; }
178
179# @FUNCTION: cmake-utils_use_build
180# @USAGE: <USE flag> [flag name]
181# @DESCRIPTION:
182# Based on use_enable. See ebuild(5).
183#
184# `cmake-utils_use_build foo FOO` echoes -DBUILD_FOO=ON if foo is enabled
185# and -DBUILD_FOO=OFF if it is disabled.
186cmake-utils_use_build() { _use_me_now BUILD_ "$@" ; }
187
188# @FUNCTION: cmake-utils_use_has
189# @USAGE: <USE flag> [flag name]
190# @DESCRIPTION:
191# Based on use_enable. See ebuild(5).
192#
193# `cmake-utils_use_has foo FOO` echoes -DHAVE_FOO=ON if foo is enabled
194# and -DHAVE_FOO=OFF if it is disabled.
195cmake-utils_use_has() { _use_me_now HAVE_ "$@" ; }
63 196
64# @FUNCTION: cmake-utils_has 197# @FUNCTION: cmake-utils_has
65# @USAGE: <USE flag> [flag name]
66# @DESCRIPTION: 198# @DESCRIPTION:
199# Deprecated, use cmake-utils_use_has, kept now for backcompat.
200cmake-utils_has() { ewarn "QA notice: using deprecated ${FUNCNAME} call, use cmake-utils_use_has instead." ; _use_me_now HAVE_ "$@" ; }
201
202# @FUNCTION: cmake-utils_use
203# @USAGE: <USE flag> [flag name]
204# @DESCRIPTION:
67# Based on use_enable. See ebuild(5). 205# Based on use_enable. See ebuild(5).
68# 206#
69# `cmake-utils_has foo FOO` echoes -DHAVE_FOO=ON if foo is enabled 207# `cmake-utils_use foo FOO` echoes -DFOO=ON if foo is enabled
70# and -DHAVE_FOO=OFF if it is disabled. 208# and -DFOO=OFF if it is disabled.
71cmake-utils_has() { _use_me_now HAVE "$@" ; } 209cmake-utils_use() { _use_me_now "" "$@" ; }
210
211# Internal function for modifying hardcoded definitions.
212# Removes dangerous definitionts that override Gentoo settings.
213_modify-cmakelists() {
214 debug-print-function ${FUNCNAME} "$@"
215
216 # Comment out all set (<some_should_be_user_defined_variable> value)
217 # TODO Add QA checker - inform when variable being checked for below is set in CMakeLists.txt
218 find "${CMAKE_USE_DIR}" -name CMakeLists.txt \
219 -exec sed -i -e '/^[[:space:]]*[sS][eE][tT][[:space:]]*([[:space:]]*CMAKE_BUILD_TYPE.*)/{s/^/#IGNORE /g}' {} + \
220 -exec sed -i -e '/^[[:space:]]*[sS][eE][tT][[:space:]]*([[:space:]]*CMAKE_INSTALL_PREFIX.*)/{s/^/#IGNORE /g}' {} + \
221 || die "${LINENO}: failed to disable hardcoded settings"
222
223 # NOTE Append some useful summary here
224 echo '
225MESSAGE(STATUS "<<< Gentoo configuration >>>
226Build type: ${CMAKE_BUILD_TYPE}
227Install path: ${CMAKE_INSTALL_PREFIX}\n")' >> CMakeLists.txt
228}
229
230# @FUNCTION: cmake-utils_src_configure
231# @DESCRIPTION:
232# General function for configuring with cmake. Default behaviour is to start an
233# out-of-source build.
234cmake-utils_src_configure() {
235 debug-print-function ${FUNCNAME} "$@"
236
237 _check_build_dir
238
239 # check if CMakeLists.txt exist and if no then die
240 if [[ ! -e "${CMAKE_USE_DIR}"/CMakeLists.txt ]] ; then
241 eerror "I was unable to locate CMakeLists.txt under:"
242 eerror "\"${CMAKE_USE_DIR}/CMakeLists.txt\""
243 eerror "You should consider not inheriting the cmake eclass."
244 die "FATAL: Unable to find CMakeLists.txt"
245 fi
246
247 # Remove dangerous things.
248 _modify-cmakelists
249
250 # @SEE CMAKE_BUILD_TYPE
251 if [[ ${CMAKE_BUILD_TYPE} = Gentoo ]]; then
252 # Handle release builds
253 if ! has debug ${IUSE//+} || ! use debug; then
254 append-cppflags -DNDEBUG
255 fi
256 fi
257
258 # Prepare Gentoo override rules (set valid compiler, append CPPFLAGS)
259 local build_rules="${TMPDIR}"/gentoo_rules.cmake
260cat > ${build_rules} << _EOF_
261SET (CMAKE_C_COMPILER $(type -P $(tc-getCC)) CACHE FILEPATH "C compiler" FORCE)
262SET (CMAKE_C_COMPILE_OBJECT "<CMAKE_C_COMPILER> <DEFINES> ${CPPFLAGS} <FLAGS> -o <OBJECT> -c <SOURCE>" CACHE STRING "C compile command" FORCE)
263SET (CMAKE_CXX_COMPILER $(type -P $(tc-getCXX)) CACHE FILEPATH "C++ compiler" FORCE)
264SET (CMAKE_CXX_COMPILE_OBJECT "<CMAKE_CXX_COMPILER> <DEFINES> ${CPPFLAGS} <FLAGS> -o <OBJECT> -c <SOURCE>" CACHE STRING "C++ compile command" FORCE)
265_EOF_
266
267 # Common configure parameters (overridable)
268 # NOTE CMAKE_BUILD_TYPE can be only overriden via CMAKE_BUILD_TYPE eclass variable
269 # No -DCMAKE_BUILD_TYPE=xxx definitions will be in effect.
270 local cmakeargs="
271 -DCMAKE_INSTALL_PREFIX=${PREFIX:-/usr}
272 ${mycmakeargs}
273 -DCMAKE_BUILD_TYPE=${CMAKE_BUILD_TYPE}
274 -DCMAKE_INSTALL_DO_STRIP=OFF
275 -DCMAKE_USER_MAKE_RULES_OVERRIDE=${build_rules}"
276
277 # Common configure parameters (invariants)
278 local common_config="${TMPDIR}"/gentoo_common_config.cmake
279 local libdir=$(get_libdir)
280cat > ${common_config} << _EOF_
281SET (LIB_SUFFIX ${libdir/lib} CACHE STRING "library path suffix" FORCE)
282_EOF_
283 [[ -n ${CMAKE_NO_COLOR} ]] && echo 'SET (CMAKE_COLOR_MAKEFILE OFF CACHE BOOL "pretty colors during make" FORCE)' >> ${common_config}
284 cmakeargs="-C ${common_config} ${cmakeargs}"
285
286 mkdir -p "${CMAKE_BUILD_DIR}"
287 pushd "${CMAKE_BUILD_DIR}" > /dev/null
288 debug-print "${LINENO} ${ECLASS} ${FUNCNAME}: mycmakeargs is $cmakeargs"
289 cmake ${cmakeargs} "${CMAKE_USE_DIR}" || die "cmake failed"
290
291 popd > /dev/null
292}
72 293
73# @FUNCTION: cmake-utils_src_compile 294# @FUNCTION: cmake-utils_src_compile
74# @DESCRIPTION: 295# @DESCRIPTION:
75# General function for compiling with cmake. Default behaviour is to start an 296# General function for compiling with cmake. Default behaviour is to check for
76# out-of-source build. All arguments are passed to cmake-utils_src_make. 297# EAPI and respectively to configure as well or just compile.
77cmake-utils_src_compile() { 298cmake-utils_src_compile() {
78 debug-print-function $FUNCNAME $* 299 debug-print-function ${FUNCNAME} "$@"
79 300
80 if [[ -n "${CMAKE_IN_SOURCE_BUILD}" ]]; then 301 has src_configure ${EXPF} || cmake-utils_src_configure
81 cmake-utils_src_configurein
82 else
83 cmake-utils_src_configureout
84 fi
85 cmake-utils_src_make "$@" 302 cmake-utils_src_make "$@"
86} 303}
87 304
88# @FUNCTION: cmake-utils_src_configurein 305# @FUNCTION: cmake-utils_src_configurein
89# @DESCRIPTION: 306# @DESCRIPTION:
90# Function for software that requires configure and building in the source 307# Deprecated
91# directory.
92cmake-utils_src_configurein() { 308cmake-utils_src_configurein() {
93 debug-print-function $FUNCNAME $* 309 ewarn "QA notice: using deprecated ${FUNCNAME} call, set CMAKE_IN_SOURCE_BUILD=1 instead."
94 310 cmake-utils_src_configure
95 local cmakeargs="$(_common_configure_code) ${mycmakeargs} ${EXTRA_ECONF}"
96
97 debug-print "$LINENO $ECLASS $FUNCNAME: mycmakeargs is $cmakeargs"
98 cmake ${cmakeargs} . || die "Cmake failed"
99} 311}
100 312
101# @FUNCTION: cmake-utils_src_configureout 313# @FUNCTION: cmake-utils_src_configureout
102# @DESCRIPTION: 314# @DESCRIPTION:
103# Function for software that requires configure and building outside the source 315# Deprecated
104# tree - default.
105cmake-utils_src_configureout() { 316cmake-utils_src_configureout() {
106 debug-print-function $FUNCNAME $* 317 ewarn "QA notice: using deprecated ${FUNCNAME} call, out of source build is enabled by default."
107 318 cmake-utils_src_configure
108 local cmakeargs="$(_common_configure_code) ${mycmakeargs} ${EXTRA_ECONF}"
109 mkdir -p "${WORKDIR}"/${PN}_build
110 pushd "${WORKDIR}"/${PN}_build > /dev/null
111
112 debug-print "$LINENO $ECLASS $FUNCNAME: mycmakeargs is $cmakeargs"
113 cmake ${cmakeargs} "${S}" || die "Cmake failed"
114
115 popd > /dev/null
116}
117
118# Internal use only. Common configuration options for all types of builds.
119_common_configure_code() {
120 local tmp_libdir=$(get_libdir)
121 if has debug ${IUSE//+} && use debug; then
122 echo -DCMAKE_BUILD_TYPE=Debug
123 else
124 echo -DCMAKE_BUILD_TYPE=Release
125 fi
126 echo -DCMAKE_C_COMPILER=$(type -P $(tc-getCC))
127 echo -DCMAKE_CXX_COMPILER=$(type -P $(tc-getCXX))
128 echo -DCMAKE_INSTALL_PREFIX=${PREFIX:-/usr}
129 echo -DLIB_SUFFIX=${tmp_libdir/lib}
130 echo -DLIB_INSTALL_DIR=${PREFIX:-/usr}/${tmp_libdir}
131 [[ -n ${CMAKE_NO_COLOR} ]] && echo -DCMAKE_COLOR_MAKEFILE=OFF
132} 319}
133 320
134# @FUNCTION: cmake-utils_src_make 321# @FUNCTION: cmake-utils_src_make
135# @DESCRIPTION: 322# @DESCRIPTION:
136# Function for building the package. Automatically detects the build type. 323# Function for building the package. Automatically detects the build type.
137# All arguments are passed to emake: 324# All arguments are passed to emake:
138# "cmake-utils_src_make -j1" can be used to work around parallel make issues.
139cmake-utils_src_make() { 325cmake-utils_src_make() {
140 debug-print-function $FUNCNAME $* 326 debug-print-function ${FUNCNAME} "$@"
141 327
142 # At this point we can automatically check if it's an out-of-source or an 328 _check_build_dir
143 # in-source build 329 pushd "${CMAKE_BUILD_DIR}" > /dev/null
144 if [[ -d ${WORKDIR}/${PN}_build ]]; then 330 # first check if Makefile exist otherwise die
145 pushd "${WORKDIR}"/${PN}_build > /dev/null 331 [[ -e Makefile ]] || die "Makefile not found. Error during configure stage."
146 fi
147 if ! [[ -z ${CMAKE_COMPILER_VERBOSE} ]]; then 332 if [[ -n ${CMAKE_VERBOSE} ]]; then
148 emake VERBOSE=1 "$@" || die "Make failed!" 333 emake VERBOSE=1 "$@" || die "Make failed!"
149 else 334 else
150 emake "$@" || die "Make failed!" 335 emake "$@" || die "Make failed!"
151 fi 336 fi
152 if [[ -d ${WORKDIR}/${PN}_build ]]; then
153 popd > /dev/null 337 popd > /dev/null
154 fi
155} 338}
156 339
157# @FUNCTION: cmake-utils_src_install 340# @FUNCTION: cmake-utils_src_install
158# @DESCRIPTION: 341# @DESCRIPTION:
159# Function for installing the package. Automatically detects the build type. 342# Function for installing the package. Automatically detects the build type.
160cmake-utils_src_install() { 343cmake-utils_src_install() {
161 debug-print-function $FUNCNAME $* 344 debug-print-function ${FUNCNAME} "$@"
162 345
163 # At this point we can automatically check if it's an out-of-source or an 346 _check_build_dir
164 # in-source build 347 pushd "${CMAKE_BUILD_DIR}" > /dev/null
165 if [[ -d ${WORKDIR}/${PN}_build ]]; then
166 pushd "${WORKDIR}"/${PN}_build > /dev/null
167 fi
168 emake install DESTDIR="${D}" || die "Make install failed" 348 emake install DESTDIR="${D}" || die "Make install failed"
169 if [[ -d ${WORKDIR}/${PN}_build ]]; then
170 popd > /dev/null 349 popd > /dev/null
171 fi
172 350
173 # Manual document installation 351 # Manual document installation
174 [[ -n "${DOCS}" ]] && dodoc ${DOCS} 352 [[ -n "${DOCS}" ]] && { dodoc ${DOCS} || die "dodoc failed" ; }
353 [[ -n "${HTML_DOCS}" ]] && { dohtml -r ${HTML_DOCS} || die "dohtml failed" ; }
175} 354}
176 355
177# @FUNCTION: cmake-utils_src_test 356# @FUNCTION: cmake-utils_src_test
178# @DESCRIPTION: 357# @DESCRIPTION:
179# Function for testing the package. Automatically detects the build type. 358# Function for testing the package. Automatically detects the build type.
180cmake-utils_src_test() { 359cmake-utils_src_test() {
181 debug-print-function $FUNCNAME $* 360 debug-print-function ${FUNCNAME} "$@"
182 361
183 # At this point we can automatically check if it's an out-of-source or an 362 _check_build_dir
184 # in-source build 363 pushd "${CMAKE_BUILD_DIR}" > /dev/null
185 if [[ -d ${WORKDIR}/${PN}_build ]]; then
186 pushd "${WORKDIR}"/${PN}_build > /dev/null
187 fi
188 # Standard implementation of src_test 364 # Standard implementation of src_test
189 if emake -j1 check -n &> /dev/null; then 365 if emake -j1 check -n &> /dev/null; then
190 einfo ">>> Test phase [check]: ${CATEGORY}/${PF}" 366 einfo ">>> Test phase [check]: ${CATEGORY}/${PF}"
191 if ! emake -j1 check; then 367 if ! emake -j1 check; then
192 die "Make check failed. See above for details." 368 die "Make check failed. See above for details."
197 die "Make test failed. See above for details." 373 die "Make test failed. See above for details."
198 fi 374 fi
199 else 375 else
200 einfo ">>> Test phase [none]: ${CATEGORY}/${PF}" 376 einfo ">>> Test phase [none]: ${CATEGORY}/${PF}"
201 fi 377 fi
202 if [[ -d ${WORKDIR}/${PN}_build ]]; then
203 popd > /dev/null 378 popd > /dev/null
204 fi
205} 379}

Legend:
Removed from v.1.7  
changed lines
  Added in v.1.26

  ViewVC Help
Powered by ViewVC 1.1.20