/[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.23 Revision 1.65
1# Copyright 1999-2009 Gentoo Foundation 1# Copyright 1999-2010 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.23 2009/04/04 12:28:10 scarabeus Exp $ 3# $Header: /var/cvsroot/gentoo-x86/eclass/cmake-utils.eclass,v 1.65 2011/01/20 00:48:51 reavertm 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# 8#
9# @CODE 9# @CODE
10# Tomáš Chvátal <scarabeus@gentoo.org> 10# Tomáš Chvátal <scarabeus@gentoo.org>
11# Maciej Mrozowski <reavertm@poczta.fm> 11# Maciej Mrozowski <reavertm@gentoo.org>
12# (undisclosed contributors) 12# (undisclosed contributors)
13# Original author: Zephyrus (zephyrus@mirach.it) 13# Original author: Zephyrus (zephyrus@mirach.it)
14# @CODE 14# @CODE
15# @BLURB: common ebuild functions for cmake-based packages 15# @BLURB: common ebuild functions for cmake-based packages
16# @DESCRIPTION: 16# @DESCRIPTION:
17# The cmake-utils eclass contains functions that make creating ebuilds for 17# The cmake-utils eclass is base.eclass(5) wrapper that makes creating ebuilds for
18# cmake-based packages much easier. 18# cmake-based packages much easier.
19# Its main features are support of out-of-source builds as well as in-source 19# It provides all inherited features (DOCS, HTML_DOCS, PATCHES) along with out-of-source
20# builds and an implementation of the well-known use_enable and use_with 20# builds (default), in-source builds and an implementation of the well-known use_enable
21# functions for CMake. 21# and use_with functions for CMake.
22 22
23# @ECLASS-VARIABLE: WANT_CMAKE
24# @DESCRIPTION:
25# Specify if cmake-utils eclass should depend on cmake optionaly or not.
26# This is usefull when only part of aplication is using cmake build system.
27# Valid values are: always [default], optional (where the value is the useflag
28# used for optionality)
29WANT_CMAKE="${WANT_CMAKE:-always}"
30
31# @ECLASS-VARIABLE: CMAKE_MIN_VERSION
32# @DESCRIPTION:
33# Specify the minimum required CMake version. Default is 2.8.1
34CMAKE_MIN_VERSION="${CMAKE_MIN_VERSION:-2.8.1}"
35
36CMAKEDEPEND=""
37case ${WANT_CMAKE} in
38 always)
39 ;;
40 *)
41 IUSE+=" ${WANT_CMAKE}"
42 CMAKEDEPEND+="${WANT_CMAKE}? ( "
43 ;;
44esac
23inherit toolchain-funcs multilib flag-o-matic base 45inherit toolchain-funcs multilib flag-o-matic base
24 46
25EXPF="src_compile src_test src_install" 47CMAKE_EXPF="src_compile src_test src_install"
26case ${EAPI:-0} in 48case ${EAPI:-0} in
27 2) EXPF="${EXPF} src_configure" 49 3|2) CMAKE_EXPF+=" src_configure" ;;
28 ;;
29 1|0) ;; 50 1|0) ;;
30 *) die "Unknown EAPI, Bug eclass maintainers." ;; 51 *) die "Unknown EAPI, Bug eclass maintainers." ;;
31esac 52esac
32EXPORT_FUNCTIONS ${EXPF} 53EXPORT_FUNCTIONS ${CMAKE_EXPF}
33 54
34: ${DESCRIPTION:="Based on the ${ECLASS} eclass"} 55: ${DESCRIPTION:="Based on the ${ECLASS} eclass"}
35 56
36if [[ ${PN} != cmake ]]; then 57if [[ ${PN} != cmake ]]; then
37 CMAKEDEPEND=">=dev-util/cmake-2.6.2-r1" 58 CMAKEDEPEND+=">=dev-util/cmake-${CMAKE_MIN_VERSION}"
38fi 59fi
39 60
61CMAKEDEPEND+=" userland_GNU? ( >=sys-apps/findutils-4.4.0 )"
62
63[[ ${WANT_CMAKE} = always ]] || CMAKEDEPEND+=" )"
64
40DEPEND="${CMAKEDEPEND} 65DEPEND="${CMAKEDEPEND}"
41 userland_GNU? ( >=sys-apps/findutils-4.4.0 ) 66unset CMAKEDEPEND
42"
43 67
44# Internal functions used by cmake-utils_use_* 68# Internal functions used by cmake-utils_use_*
45_use_me_now() { 69_use_me_now() {
46 debug-print-function ${FUNCNAME} "$@" 70 debug-print-function ${FUNCNAME} "$@"
47 71
75 echo "-D$1$x=$(use $2 && echo OFF || echo ON) " 99 echo "-D$1$x=$(use $2 && echo OFF || echo ON) "
76 done 100 done
77 fi 101 fi
78} 102}
79 103
80# @ECLASS-VARIABLE: DOCS
81# @DESCRIPTION:
82# Documents passed to dodoc command.
83
84# @ECLASS-VARIABLE: HTML_DOCS
85# @DESCRIPTION:
86# Documents passed to dohtml command.
87
88# @ECLASS-VARIABLE: PREFIX
89# @DESCRIPTION:
90# Eclass respects PREFIX variable, though it's not recommended way to set
91# install/lib/bin prefixes.
92# Use -DCMAKE_INSTALL_PREFIX=... CMake variable instead.
93
94# @ECLASS-VARIABLE: CMAKE_IN_SOURCE_BUILD 104# @ECLASS-VARIABLE: CMAKE_BUILD_DIR
95# @DESCRIPTION: 105# @DESCRIPTION:
96# Set to enable in-source build. 106# Build directory where all cmake processed files should be generated.
97 107# For in-source build it's fixed to ${CMAKE_USE_DIR}.
98# @ECLASS-VARIABLE: CMAKE_NO_COLOR 108# For out-of-source build it can be overriden, by default it uses
99# @DESCRIPTION: 109# ${WORKDIR}/${P}_build.
100# Set to disable cmake output coloring.
101
102# @ECLASS-VARIABLE: CMAKE_VERBOSE
103# @DESCRIPTION:
104# Set to enable verbose messages during compilation.
105 110
106# @ECLASS-VARIABLE: CMAKE_BUILD_TYPE 111# @ECLASS-VARIABLE: CMAKE_BUILD_TYPE
107# @DESCRIPTION: 112# @DESCRIPTION:
108# Set to override default CMAKE_BUILD_TYPE. Only useful for packages 113# Set to override default CMAKE_BUILD_TYPE. Only useful for packages
109# known to make use of "if (CMAKE_BUILD_TYPE MATCHES xxx)". 114# known to make use of "if (CMAKE_BUILD_TYPE MATCHES xxx)".
110# If about to be set - needs to be set before invoking cmake-utils_src_configure. 115# If about to be set - needs to be set before invoking cmake-utils_src_configure.
111# You usualy do *NOT* want nor need to set it as it pulls CMake default build-type 116# You usualy do *NOT* want nor need to set it as it pulls CMake default build-type
112# specific compiler flags overriding make.conf. 117# specific compiler flags overriding make.conf.
113: ${CMAKE_BUILD_TYPE:=Gentoo} 118: ${CMAKE_BUILD_TYPE:=Gentoo}
114 119
115# @FUNCTION: _check_build_dir 120# @ECLASS-VARIABLE: CMAKE_IN_SOURCE_BUILD
116# @DESCRIPTION: 121# @DESCRIPTION:
122# Set to enable in-source build.
123
124# @ECLASS-VARIABLE: CMAKE_USE_DIR
125# @DESCRIPTION:
126# Sets the directory where we are working with cmake.
127# For example when application uses autotools and only one
128# plugin needs to be done by cmake.
129# By default it uses ${S}.
130
131# @ECLASS-VARIABLE: CMAKE_VERBOSE
132# @DESCRIPTION:
133# Set to enable verbose messages during compilation.
134
135# @ECLASS-VARIABLE: PREFIX
136# @DESCRIPTION:
137# Eclass respects PREFIX variable, though it's not recommended way to set
138# install/lib/bin prefixes.
139# Use -DCMAKE_INSTALL_PREFIX=... CMake variable instead.
140
141# @ECLASS-VARIABLE: CMAKE_BINARY
142# @DESCRIPTION:
143# Eclass can use different cmake binary than the one provided in by system.
144: ${CMAKE_BINARY:=cmake}
145
117# Determine using IN or OUT source build 146# Determine using IN or OUT source build
118_check_build_dir() { 147_check_build_dir() {
119 # in/out source build 148 : ${CMAKE_USE_DIR:=${S}}
120 if [[ -n "${CMAKE_IN_SOURCE_BUILD}" ]]; then 149 if [[ -n ${CMAKE_IN_SOURCE_BUILD} ]]; then
150 # we build in source dir
121 CMAKE_BUILD_DIR="${S}" 151 CMAKE_BUILD_DIR="${CMAKE_USE_DIR}"
122 else 152 else
123 CMAKE_BUILD_DIR="${WORKDIR}/${PN}_build" 153 : ${CMAKE_BUILD_DIR:=${WORKDIR}/${P}_build}
124 fi 154 fi
125 echo ">>> Working in BUILD_DIR: \"$CMAKE_BUILD_DIR\"" 155 echo ">>> Working in BUILD_DIR: \"$CMAKE_BUILD_DIR\""
126} 156}
127# @FUNCTION: cmake-utils_use_with 157# @FUNCTION: cmake-utils_use_with
128# @USAGE: <USE flag> [flag name] 158# @USAGE: <USE flag> [flag name]
185# 215#
186# `cmake-utils_use_has foo FOO` echoes -DHAVE_FOO=ON if foo is enabled 216# `cmake-utils_use_has foo FOO` echoes -DHAVE_FOO=ON if foo is enabled
187# and -DHAVE_FOO=OFF if it is disabled. 217# and -DHAVE_FOO=OFF if it is disabled.
188cmake-utils_use_has() { _use_me_now HAVE_ "$@" ; } 218cmake-utils_use_has() { _use_me_now HAVE_ "$@" ; }
189 219
190# @FUNCTION: cmake-utils_has 220# @FUNCTION: cmake-utils_use_use
221# @USAGE: <USE flag> [flag name]
191# @DESCRIPTION: 222# @DESCRIPTION:
192# Deprecated, use cmake-utils_use_has, kept now for backcompat. 223# Based on use_enable. See ebuild(5).
193cmake-utils_has() { ewarn "QA notice: using deprecated ${FUNCNAME} call, use cmake-utils_use_has instead." ; _use_me_now HAVE_ "$@" ; } 224#
225# `cmake-utils_use_use foo FOO` echoes -DUSE_FOO=ON if foo is enabled
226# and -DUSE_FOO=OFF if it is disabled.
227cmake-utils_use_use() { _use_me_now USE_ "$@" ; }
194 228
195# @FUNCTION: cmake-utils_use 229# @FUNCTION: cmake-utils_use
196# @USAGE: <USE flag> [flag name] 230# @USAGE: <USE flag> [flag name]
197# @DESCRIPTION: 231# @DESCRIPTION:
198# Based on use_enable. See ebuild(5). 232# Based on use_enable. See ebuild(5).
200# `cmake-utils_use foo FOO` echoes -DFOO=ON if foo is enabled 234# `cmake-utils_use foo FOO` echoes -DFOO=ON if foo is enabled
201# and -DFOO=OFF if it is disabled. 235# and -DFOO=OFF if it is disabled.
202cmake-utils_use() { _use_me_now "" "$@" ; } 236cmake-utils_use() { _use_me_now "" "$@" ; }
203 237
204# Internal function for modifying hardcoded definitions. 238# Internal function for modifying hardcoded definitions.
205# Removes dangerous definitionts that override Gentoo settings. 239# Removes dangerous definitions that override Gentoo settings.
206_modify-cmakelists() { 240_modify-cmakelists() {
207 debug-print-function ${FUNCNAME} "$@" 241 debug-print-function ${FUNCNAME} "$@"
208 242
209 # Comment out all set (<some_should_be_user_defined_variable> value) 243 # Comment out all set (<some_should_be_user_defined_variable> value)
210 # TODO Add QA checker - inform when variable being checked for below is set in CMakeLists.txt 244 # TODO Add QA checker - inform when variable being checked for below is set in CMakeLists.txt
211 find "${S}" -name CMakeLists.txt \ 245 find "${CMAKE_USE_DIR}" -name CMakeLists.txt \
212 -exec sed -i -e '/^[[:space:]]*[sS][eE][tT][[:space:]]*([[:space:]]*CMAKE_BUILD_TYPE.*)/{s/^/#IGNORE /g}' {} + \ 246 -exec sed -i -e '/^[[:space:]]*[sS][eE][tT][[:space:]]*([[:space:]]*CMAKE_BUILD_TYPE.*)/{s/^/#IGNORE /g}' {} + \
247 -exec sed -i -e '/^[[:space:]]*[sS][eE][tT][[:space:]]*([[:space:]]*CMAKE_COLOR_MAKEFILE.*)/{s/^/#IGNORE /g}' {} + \
213 -exec sed -i -e '/^[[:space:]]*[sS][eE][tT][[:space:]]*([[:space:]]*CMAKE_INSTALL_PREFIX.*)/{s/^/#IGNORE /g}' {} + \ 248 -exec sed -i -e '/^[[:space:]]*[sS][eE][tT][[:space:]]*([[:space:]]*CMAKE_INSTALL_PREFIX.*)/{s/^/#IGNORE /g}' {} + \
249 -exec sed -i -e '/^[[:space:]]*[sS][eE][tT][[:space:]]*([[:space:]]*CMAKE_VERBOSE_MAKEFILE.*)/{s/^/#IGNORE /g}' {} + \
214 || die "${LINENO}: failed to disable hardcoded settings" 250 || die "${LINENO}: failed to disable hardcoded settings"
215 251
216 # NOTE Append some useful summary here 252 # NOTE Append some useful summary here
217 echo ' 253 cat >> CMakeLists.txt <<- _EOF_
254
218MESSAGE(STATUS "<<< Gentoo configuration >>> 255 MESSAGE(STATUS "<<< Gentoo configuration >>>
219Build type: ${CMAKE_BUILD_TYPE} 256 Build type \${CMAKE_BUILD_TYPE}
220Install path: ${CMAKE_INSTALL_PREFIX}\n")' >> CMakeLists.txt 257 Install path \${CMAKE_INSTALL_PREFIX}
258 Compiler flags:
259 C \${CMAKE_C_FLAGS}
260 C++ \${CMAKE_CXX_FLAGS}
261 Linker flags:
262 Executable \${CMAKE_EXE_LINKER_FLAGS}
263 Module \${CMAKE_MODULE_LINKER_FLAGS}
264 Shared \${CMAKE_SHARED_LINKER_FLAGS}\n")
265 _EOF_
221} 266}
222 267
223# @FUNCTION: cmake-utils_src_configure
224# @DESCRIPTION:
225# General function for configuring with cmake. Default behaviour is to start an
226# out-of-source build.
227cmake-utils_src_configure() { 268enable_cmake-utils_src_configure() {
228 debug-print-function ${FUNCNAME} "$@" 269 debug-print-function ${FUNCNAME} "$@"
270
271 _check_build_dir
272
273 # check if CMakeLists.txt exist and if no then die
274 if [[ ! -e ${CMAKE_USE_DIR}/CMakeLists.txt ]] ; then
275 eerror "Unable to locate CMakeLists.txt under:"
276 eerror "\"${CMAKE_USE_DIR}/CMakeLists.txt\""
277 eerror "Consider not inheriting the cmake eclass."
278 die "FATAL: Unable to find CMakeLists.txt"
279 fi
229 280
230 # Remove dangerous things. 281 # Remove dangerous things.
231 _modify-cmakelists 282 _modify-cmakelists
283
284 # Fix xdg collision with sandbox
285 export XDG_CONFIG_HOME="${T}"
232 286
233 # @SEE CMAKE_BUILD_TYPE 287 # @SEE CMAKE_BUILD_TYPE
234 if [[ ${CMAKE_BUILD_TYPE} = Gentoo ]]; then 288 if [[ ${CMAKE_BUILD_TYPE} = Gentoo ]]; then
235 # Handle release builds 289 # Handle release builds
236 if ! has debug ${IUSE//+} || ! use debug; then 290 if ! has debug ${IUSE//+} || ! use debug; then
237 append-cppflags -DNDEBUG 291 append-cppflags -DNDEBUG
238 fi 292 fi
239 fi 293 fi
240 294
241 # Prepare Gentoo override rules (set valid compiler, append CPPFLAGS) 295 # Prepare Gentoo override rules (set valid compiler, append CPPFLAGS)
242 local build_rules="${TMPDIR}"/gentoo_rules.cmake 296 local build_rules=${T}/gentoo_rules.cmake
243cat > ${build_rules} << _EOF_ 297 cat > "${build_rules}" <<- _EOF_
244SET (CMAKE_C_COMPILER $(type -P $(tc-getCC)) CACHE FILEPATH "C compiler" FORCE) 298 SET (CMAKE_C_COMPILER $(type -P $(tc-getCC)) CACHE FILEPATH "C compiler" FORCE)
245SET (CMAKE_C_COMPILE_OBJECT "<CMAKE_C_COMPILER> <DEFINES> ${CPPFLAGS} <FLAGS> -o <OBJECT> -c <SOURCE>" CACHE STRING "C compile command" FORCE) 299 SET (CMAKE_C_COMPILE_OBJECT "<CMAKE_C_COMPILER> <DEFINES> ${CPPFLAGS} <FLAGS> -o <OBJECT> -c <SOURCE>" CACHE STRING "C compile command" FORCE)
246SET (CMAKE_CXX_COMPILER $(type -P $(tc-getCXX)) CACHE FILEPATH "C++ compiler" FORCE) 300 SET (CMAKE_CXX_COMPILER $(type -P $(tc-getCXX)) CACHE FILEPATH "C++ compiler" FORCE)
247SET (CMAKE_CXX_COMPILE_OBJECT "<CMAKE_CXX_COMPILER> <DEFINES> ${CPPFLAGS} <FLAGS> -o <OBJECT> -c <SOURCE>" CACHE STRING "C++ compile command" FORCE) 301 SET (CMAKE_CXX_COMPILE_OBJECT "<CMAKE_CXX_COMPILER> <DEFINES> ${CPPFLAGS} <FLAGS> -o <OBJECT> -c <SOURCE>" CACHE STRING "C++ compile command" FORCE)
248_EOF_ 302 _EOF_
303
304 if use prefix; then
305 cat >> "${build_rules}" <<- _EOF_
306 # in Prefix we need rpath and must ensure cmake gets our default linker path
307 # right ... except for Darwin hosts
308 IF (NOT APPLE)
309 SET (CMAKE_SKIP_RPATH OFF CACHE BOOL "" FORCE)
310 SET (CMAKE_PLATFORM_REQUIRED_RUNTIME_PATH "${EPREFIX}/usr/${CHOST}/lib/gcc;${EPREFIX}/usr/${CHOST}/lib;${EPREFIX}/usr/$(get_libdir);${EPREFIX}/$(get_libdir)"
311 CACHE STRING "" FORCE)
312
313 ELSE ()
314
315 SET(CMAKE_PREFIX_PATH "${EPREFIX}${PREFIX:-/usr}" CACHE STRING ""FORCE)
316 SET(CMAKE_SKIP_BUILD_RPATH OFF CACHE BOOL "" FORCE)
317 SET(CMAKE_SKIP_RPATH OFF CACHE BOOL "" FORCE)
318 SET(CMAKE_BUILD_WITH_INSTALL_RPATH TRUE CACHE BOOL "" FORCE)
319 SET(CMAKE_INSTALL_RPATH "${EPREFIX}${PREFIX:-/usr}/lib;${EPREFIX}/usr/${CHOST}/lib/gcc;${EPREFIX}/usr/${CHOST}/lib;${EPREFIX}/usr/$(get_libdir);${EPREFIX}/$(get_libdir)" CACHE STRING "" FORCE)
320 SET(CMAKE_INSTALL_RPATH_USE_LINK_PATH TRUE CACHE BOOL "" FORCE)
321 SET(CMAKE_INSTALL_NAME_DIR "${EPREFIX}${PREFIX:-/usr}/lib" CACHE STRING "" FORCE)
322
323 ENDIF (NOT APPLE)
324 _EOF_
325 fi
326
327 # Common configure parameters (invariants)
328 local common_config=${T}/gentoo_common_config.cmake
329 local libdir=$(get_libdir)
330 cat > "${common_config}" <<- _EOF_
331 SET (LIB_SUFFIX ${libdir/lib} CACHE STRING "library path suffix" FORCE)
332 SET (CMAKE_INSTALL_LIBDIR ${libdir} CACHE PATH "Output directory for libraries")
333 _EOF_
334 [[ "${NOCOLOR}" = true || "${NOCOLOR}" = yes ]] && echo 'SET (CMAKE_COLOR_MAKEFILE OFF CACHE BOOL "pretty colors during make" FORCE)' >> "${common_config}"
335
336 # Convert mycmakeargs to an array, for backwards compatibility
337 # Make the array a local variable since <=portage-2.1.6.x does not
338 # support global arrays (see bug #297255).
339 if [[ $(declare -p mycmakeargs 2>&-) != "declare -a mycmakeargs="* ]]; then
340 local mycmakeargs_local=(${mycmakeargs})
341 else
342 local mycmakeargs_local=("${mycmakeargs[@]}")
343 fi
344
345 has "${EAPI:-0}" 0 1 2 && ! use prefix && EPREFIX=
249 346
250 # Common configure parameters (overridable) 347 # Common configure parameters (overridable)
251 # NOTE CMAKE_BUILD_TYPE can be only overriden via CMAKE_BUILD_TYPE eclass variable 348 # NOTE CMAKE_BUILD_TYPE can be only overriden via CMAKE_BUILD_TYPE eclass variable
252 # No -DCMAKE_BUILD_TYPE=xxx definitions will be in effect. 349 # No -DCMAKE_BUILD_TYPE=xxx definitions will be in effect.
253 local cmakeargs=" 350 local cmakeargs=(
351 -C "${common_config}"
254 -DCMAKE_INSTALL_PREFIX=${PREFIX:-/usr} 352 -DCMAKE_INSTALL_PREFIX="${EPREFIX}${PREFIX:-/usr}"
255 ${mycmakeargs} 353 "${mycmakeargs_local[@]}"
256 -DCMAKE_BUILD_TYPE=${CMAKE_BUILD_TYPE} 354 -DCMAKE_BUILD_TYPE="${CMAKE_BUILD_TYPE}"
257 -DCMAKE_INSTALL_DO_STRIP=OFF 355 -DCMAKE_INSTALL_DO_STRIP=OFF
258 -DCMAKE_USER_MAKE_RULES_OVERRIDE=${build_rules}" 356 -DCMAKE_USER_MAKE_RULES_OVERRIDE="${build_rules}"
357 "${MYCMAKEARGS}"
358 )
259 359
260 # Common configure parameters (invariants)
261 local common_config="${TMPDIR}"/gentoo_common_config.cmake
262 local libdir=$(get_libdir)
263cat > ${common_config} << _EOF_
264SET (LIB_SUFFIX ${libdir/lib} CACHE STRING "library path suffix" FORCE)
265_EOF_
266 [[ -n ${CMAKE_NO_COLOR} ]] && echo 'SET (CMAKE_COLOR_MAKEFILE OFF CACHE BOOL "pretty colors during make" FORCE)' >> ${common_config}
267 cmakeargs="-C ${common_config} ${cmakeargs}"
268
269 _check_build_dir
270 mkdir -p "${CMAKE_BUILD_DIR}" 360 mkdir -p "${CMAKE_BUILD_DIR}"
271 pushd "${CMAKE_BUILD_DIR}" > /dev/null 361 pushd "${CMAKE_BUILD_DIR}" > /dev/null
272 debug-print "${LINENO} ${ECLASS} ${FUNCNAME}: mycmakeargs is $cmakeargs" 362 debug-print "${LINENO} ${ECLASS} ${FUNCNAME}: mycmakeargs is ${mycmakeargs_local[*]}"
273 cmake ${cmakeargs} "${S}" || die "cmake failed" 363 echo "${CMAKE_BINARY}" "${cmakeargs[@]}" "${CMAKE_USE_DIR}"
274 364 "${CMAKE_BINARY}" "${cmakeargs[@]}" "${CMAKE_USE_DIR}" || die "cmake failed"
275 popd > /dev/null 365 popd > /dev/null
366}
367
368enable_cmake-utils_src_compile() {
369 debug-print-function ${FUNCNAME} "$@"
370
371 has src_configure ${CMAKE_EXPF} || cmake-utils_src_configure
372 cmake-utils_src_make "$@"
373}
374
375# @FUNCTION: cmake-utils_src_make
376# @DESCRIPTION:
377# Function for building the package. Automatically detects the build type.
378# All arguments are passed to emake.
379cmake-utils_src_make() {
380 debug-print-function ${FUNCNAME} "$@"
381
382 _check_build_dir
383 pushd "${CMAKE_BUILD_DIR}" > /dev/null
384 # first check if Makefile exist otherwise die
385 [[ -e Makefile ]] || die "Makefile not found. Error during configure stage."
386 if [[ -n ${CMAKE_VERBOSE} ]]; then
387 emake VERBOSE=1 "$@" || die "Make failed!"
388 else
389 emake "$@" || die "Make failed!"
390 fi
391 popd > /dev/null
392}
393
394enable_cmake-utils_src_install() {
395 debug-print-function ${FUNCNAME} "$@"
396
397 _check_build_dir
398 pushd "${CMAKE_BUILD_DIR}" > /dev/null
399 base_src_install "$@"
400 popd > /dev/null
401
402 # Backward compatibility, for non-array variables
403 if [[ -n "${DOCS}" ]] && [[ "$(declare -p DOCS 2>/dev/null 2>&1)" != "declare -a"* ]]; then
404 dodoc ${DOCS} || die "dodoc failed"
405 fi
406 if [[ -n "${HTML_DOCS}" ]] && [[ "$(declare -p HTML_DOCS 2>/dev/null 2>&1)" != "declare -a"* ]]; then
407 dohtml -r ${HTML_DOCS} || die "dohtml failed"
408 fi
409}
410
411enable_cmake-utils_src_test() {
412 debug-print-function ${FUNCNAME} "$@"
413
414 _check_build_dir
415 pushd "${CMAKE_BUILD_DIR}" > /dev/null
416 local ctestargs
417 [[ -n ${TEST_VERBOSE} ]] && ctestargs="--extra-verbose --output-on-failure"
418 ctest ${ctestargs} "$@" || die "Tests failed."
419 popd > /dev/null
420}
421
422# @FUNCTION: cmake-utils_src_configure
423# @DESCRIPTION:
424# General function for configuring with cmake. Default behaviour is to start an
425# out-of-source build.
426cmake-utils_src_configure() {
427 _execute_optionaly "src_configure" "$@"
276} 428}
277 429
278# @FUNCTION: cmake-utils_src_compile 430# @FUNCTION: cmake-utils_src_compile
279# @DESCRIPTION: 431# @DESCRIPTION:
280# General function for compiling with cmake. Default behaviour is to check for 432# General function for compiling with cmake. Default behaviour is to check for
281# EAPI and respectively to configure as well or just compile. 433# EAPI and respectively to configure as well or just compile.
434# Automatically detects the build type. All arguments are passed to emake.
282cmake-utils_src_compile() { 435cmake-utils_src_compile() {
283 debug-print-function ${FUNCNAME} "$@" 436 _execute_optionaly "src_compile" "$@"
284
285 has src_configure ${EXPF} || cmake-utils_src_configure
286 cmake-utils_src_make "$@"
287}
288
289# @FUNCTION: cmake-utils_src_configurein
290# @DESCRIPTION:
291# Deprecated
292cmake-utils_src_configurein() {
293 ewarn "QA notice: using deprecated ${FUNCNAME} call, set CMAKE_IN_SOURCE_BUILD=1 instead."
294 cmake-utils_src_configure
295}
296
297# @FUNCTION: cmake-utils_src_configureout
298# @DESCRIPTION:
299# Deprecated
300cmake-utils_src_configureout() {
301 ewarn "QA notice: using deprecated ${FUNCNAME} call, out of source build is enabled by default."
302 cmake-utils_src_configure
303}
304
305# @FUNCTION: cmake-utils_src_make
306# @DESCRIPTION:
307# Function for building the package. Automatically detects the build type.
308# All arguments are passed to emake:
309cmake-utils_src_make() {
310 debug-print-function ${FUNCNAME} "$@"
311
312 _check_build_dir
313 pushd "${CMAKE_BUILD_DIR}" > /dev/null
314 if [[ -n ${CMAKE_VERBOSE} ]]; then
315 emake VERBOSE=1 "$@" || die "Make failed!"
316 else
317 emake "$@" || die "Make failed!"
318 fi
319 popd > /dev/null
320} 437}
321 438
322# @FUNCTION: cmake-utils_src_install 439# @FUNCTION: cmake-utils_src_install
323# @DESCRIPTION: 440# @DESCRIPTION:
324# Function for installing the package. Automatically detects the build type. 441# Function for installing the package. Automatically detects the build type.
325cmake-utils_src_install() { 442cmake-utils_src_install() {
326 debug-print-function ${FUNCNAME} "$@" 443 _execute_optionaly "src_install" "$@"
327
328 _check_build_dir
329 pushd "${CMAKE_BUILD_DIR}" > /dev/null
330 emake install DESTDIR="${D}" || die "Make install failed"
331 popd > /dev/null
332
333 # Manual document installation
334 [[ -n "${DOCS}" ]] && { dodoc ${DOCS} || die "dodoc failed" ; }
335 [[ -n "${HTML_DOCS}" ]] && { dohtml -r ${HTML_DOCS} || die "dohtml failed" ; }
336} 444}
337 445
338# @FUNCTION: cmake-utils_src_test 446# @FUNCTION: cmake-utils_src_test
339# @DESCRIPTION: 447# @DESCRIPTION:
340# Function for testing the package. Automatically detects the build type. 448# Function for testing the package. Automatically detects the build type.
341cmake-utils_src_test() { 449cmake-utils_src_test() {
342 debug-print-function ${FUNCNAME} "$@" 450 _execute_optionaly "src_test" "$@"
451}
343 452
344 _check_build_dir 453# Optionally executes phases based on WANT_CMAKE variable/USE flag.
345 pushd "${CMAKE_BUILD_DIR}" > /dev/null 454_execute_optionaly() {
346 # Standard implementation of src_test 455 local phase="$1" ; shift
347 if emake -j1 check -n &> /dev/null; then 456 if [[ ${WANT_CMAKE} = always ]]; then
348 einfo ">>> Test phase [check]: ${CATEGORY}/${PF}" 457 enable_cmake-utils_${phase} "$@"
349 if ! emake -j1 check; then 458 else
350 die "Make check failed. See above for details." 459 use ${WANT_CMAKE} && enable_cmake-utils_${phase} "$@"
351 fi 460 fi
352 elif emake -j1 test -n &> /dev/null; then
353 einfo ">>> Test phase [test]: ${CATEGORY}/${PF}"
354 if ! emake -j1 test; then
355 die "Make test failed. See above for details."
356 fi
357 else
358 einfo ">>> Test phase [none]: ${CATEGORY}/${PF}"
359 fi
360 popd > /dev/null
361} 461}

Legend:
Removed from v.1.23  
changed lines
  Added in v.1.65

  ViewVC Help
Powered by ViewVC 1.1.20