/[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.13 Revision 1.35
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.13 2008/10/27 14:38:38 vapier Exp $ 3# $Header: /var/cvsroot/gentoo-x86/eclass/cmake-utils.eclass,v 1.35 2009/12/10 17:35:52 abcd 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) 23# @ECLASS-VARIABLE: WANT_CMAKE
17 24# @DESCRIPTION:
18inherit toolchain-funcs multilib 25# Specify if cmake-utils eclass should depend on cmake optionaly or not.
19 26# This is usefull when only part of aplication is using cmake build system.
20DESCRIPTION="Based on the ${ECLASS} eclass" 27# Valid values are: always [default], optional (where the value is the useflag
21 28# used for optionality)
22DEPEND=">=dev-util/cmake-2.4.6" 29WANT_CMAKE="${WANT_CMAKE:-always}"
23 30CMAKEDEPEND=""
24case ${EAPI} in 31case ${WANT_CMAKE} in
25 2) 32 always)
26 EXPORT_FUNCTIONS src_configure src_compile src_test src_install
27 ;; 33 ;;
28 *) 34 *)
29 EXPORT_FUNCTIONS src_compile src_test src_install 35 IUSE+=" ${WANT_CMAKE}"
36 CMAKEDEPEND+="${WANT_CMAKE}? ( "
30 ;; 37 ;;
31esac 38esac
39inherit toolchain-funcs multilib flag-o-matic base
32 40
41CMAKE_EXPF="src_compile src_test src_install"
42case ${EAPI:-0} in
43 3|2) CMAKE_EXPF+=" src_configure" ;;
44 1|0) ;;
45 *) die "Unknown EAPI, Bug eclass maintainers." ;;
46esac
47EXPORT_FUNCTIONS ${CMAKE_EXPF}
33 48
34# Internal function use by cmake-utils_use_with and cmake-utils_use_enable 49: ${DESCRIPTION:="Based on the ${ECLASS} eclass"}
50
51if [[ ${PN} != cmake ]]; then
52 CMAKEDEPEND+=">=dev-util/cmake-2.6.2-r1"
53fi
54
55CMAKEDEPEND+=" userland_GNU? ( >=sys-apps/findutils-4.4.0 )"
56
57[[ ${WANT_CMAKE} = always ]] || CMAKEDEPEND+=" )"
58
59DEPEND="${CMAKEDEPEND}"
60unset CMAKEDEPEND
61
62# Internal functions used by cmake-utils_use_*
35_use_me_now() { 63_use_me_now() {
36 debug-print-function $FUNCNAME $* 64 debug-print-function ${FUNCNAME} "$@"
65
66 local uper capitalised x
37 [[ -z $2 ]] && die "cmake-utils_use-$1 <USE flag> [<flag name>]" 67 [[ -z $2 ]] && die "cmake-utils_use-$1 <USE flag> [<flag name>]"
68 if [[ ! -z $3 ]]; then
69 # user specified the use name so use it
38 echo "-D$1_${3:-$2}=$(use $2 && echo ON || echo OFF)" 70 echo "-D$1$3=$(use $2 && echo ON || echo OFF)"
71 else
72 # use all various most used combinations
73 uper=$(echo ${2} | tr '[:lower:]' '[:upper:]')
74 capitalised=$(echo ${2} | sed 's/\<\(.\)\([^ ]*\)/\u\1\L\2/g')
75 for x in $2 $uper $capitalised; do
76 echo "-D$1$x=$(use $2 && echo ON || echo OFF) "
77 done
78 fi
39} 79}
80_use_me_now_inverted() {
81 debug-print-function ${FUNCNAME} "$@"
40 82
83 local uper capitalised x
84 [[ -z $2 ]] && die "cmake-utils_use-$1 <USE flag> [<flag name>]"
85 if [[ ! -z $3 ]]; then
86 # user specified the use name so use it
87 echo "-D$1$3=$(use $2 && echo OFF || echo ON)"
88 else
89 # use all various most used combinations
90 uper=$(echo ${2} | tr '[:lower:]' '[:upper:]')
91 capitalised=$(echo ${2} | sed 's/\<\(.\)\([^ ]*\)/\u\1\L\2/g')
92 for x in $2 $uper $capitalised; do
93 echo "-D$1$x=$(use $2 && echo OFF || echo ON) "
94 done
95 fi
96}
97
41# @VARIABLE: DOCS 98# @ECLASS-VARIABLE: DOCS
99# @DESCRIPTION:
100# Documents passed to dodoc command.
101
102# @ECLASS-VARIABLE: HTML_DOCS
103# @DESCRIPTION:
104# Documents passed to dohtml command.
105
106# @ECLASS-VARIABLE: PREFIX
107# @DESCRIPTION:
108# Eclass respects PREFIX variable, though it's not recommended way to set
109# install/lib/bin prefixes.
110# Use -DCMAKE_INSTALL_PREFIX=... CMake variable instead.
111
112# @ECLASS-VARIABLE: CMAKE_IN_SOURCE_BUILD
113# @DESCRIPTION:
114# Set to enable in-source build.
115
116# @ECLASS-VARIABLE: CMAKE_NO_COLOR
117# @DESCRIPTION:
118# Set to disable cmake output coloring.
119
120# @ECLASS-VARIABLE: CMAKE_VERBOSE
121# @DESCRIPTION:
122# Set to enable verbose messages during compilation.
123
124# @ECLASS-VARIABLE: CMAKE_BUILD_TYPE
125# @DESCRIPTION:
126# Set to override default CMAKE_BUILD_TYPE. Only useful for packages
127# known to make use of "if (CMAKE_BUILD_TYPE MATCHES xxx)".
128# If about to be set - needs to be set before invoking cmake-utils_src_configure.
129# You usualy do *NOT* want nor need to set it as it pulls CMake default build-type
130# specific compiler flags overriding make.conf.
131: ${CMAKE_BUILD_TYPE:=Gentoo}
132
133# @FUNCTION: _check_build_dir
134# @DESCRIPTION:
135# Determine using IN or OUT source build
136_check_build_dir() {
137 # @ECLASS-VARIABLE: CMAKE_USE_DIR
42# @DESCRIPTION: 138 # @DESCRIPTION:
43# Documents to dodoc 139 # Sets the directory where we are working with cmake.
140 # For example when application uses autotools and only one
141 # plugin needs to be done by cmake.
142 # By default it uses ${S}.
143 : ${CMAKE_USE_DIR:=${S}}
44 144
145 # @ECLASS-VARIABLE: CMAKE_BUILD_DIR
146 # @DESCRIPTION:
147 # Specify the build directory where all cmake processed
148 # files should be located.
149 #
150 # For installing binary doins "${CMAKE_BUILD_DIR}/${PN}"
151 if [[ -n ${CMAKE_IN_SOURCE_BUILD} ]]; then
152 # we build in source dir
153 CMAKE_BUILD_DIR="${CMAKE_USE_DIR}"
154 elif [[ ${CMAKE_USE_DIR} = ${WORKDIR} ]]; then
155 # out of tree build, but with $S=$WORKDIR, see bug #273949 for reason.
156 CMAKE_BUILD_DIR="${CMAKE_USE_DIR}/build"
157 else
158 # regular out of tree build
159 [[ ${1} = init || -d ${CMAKE_USE_DIR}_build ]] && SUF="_build" || SUF=""
160 CMAKE_BUILD_DIR="${CMAKE_USE_DIR}${SUF}"
161
162 fi
163 echo ">>> Working in BUILD_DIR: \"$CMAKE_BUILD_DIR\""
164}
45# @FUNCTION: cmake-utils_use_with 165# @FUNCTION: cmake-utils_use_with
46# @USAGE: <USE flag> [flag name] 166# @USAGE: <USE flag> [flag name]
47# @DESCRIPTION: 167# @DESCRIPTION:
48# Based on use_with. See ebuild(5). 168# Based on use_with. See ebuild(5).
49# 169#
50# `cmake-utils_use_with foo FOO` echoes -DWITH_FOO=ON if foo is enabled 170# `cmake-utils_use_with foo FOO` echoes -DWITH_FOO=ON if foo is enabled
51# and -DWITH_FOO=OFF if it is disabled. 171# and -DWITH_FOO=OFF if it is disabled.
52cmake-utils_use_with() { _use_me_now WITH "$@" ; } 172cmake-utils_use_with() { _use_me_now WITH_ "$@" ; }
53 173
54# @FUNCTION: cmake-utils_use_enable 174# @FUNCTION: cmake-utils_use_enable
55# @USAGE: <USE flag> [flag name] 175# @USAGE: <USE flag> [flag name]
56# @DESCRIPTION: 176# @DESCRIPTION:
57# Based on use_enable. See ebuild(5). 177# Based on use_enable. See ebuild(5).
58# 178#
59# `cmake-utils_use_enable foo FOO` echoes -DENABLE_FOO=ON if foo is enabled 179# `cmake-utils_use_enable foo FOO` echoes -DENABLE_FOO=ON if foo is enabled
60# and -DENABLE_FOO=OFF if it is disabled. 180# and -DENABLE_FOO=OFF if it is disabled.
61cmake-utils_use_enable() { _use_me_now ENABLE "$@" ; } 181cmake-utils_use_enable() { _use_me_now ENABLE_ "$@" ; }
182
183# @FUNCTION: cmake-utils_use_disable
184# @USAGE: <USE flag> [flag name]
185# @DESCRIPTION:
186# Based on inversion of use_enable. See ebuild(5).
187#
188# `cmake-utils_use_enable foo FOO` echoes -DDISABLE_FOO=OFF if foo is enabled
189# and -DDISABLE_FOO=ON if it is disabled.
190cmake-utils_use_disable() { _use_me_now_inverted DISABLE_ "$@" ; }
191
192# @FUNCTION: cmake-utils_use_no
193# @USAGE: <USE flag> [flag name]
194# @DESCRIPTION:
195# Based on use_disable. See ebuild(5).
196#
197# `cmake-utils_use_no foo FOO` echoes -DNO_FOO=OFF if foo is enabled
198# and -DNO_FOO=ON if it is disabled.
199cmake-utils_use_no() { _use_me_now_inverted NO_ "$@" ; }
62 200
63# @FUNCTION: cmake-utils_use_want 201# @FUNCTION: cmake-utils_use_want
64# @USAGE: <USE flag> [flag name] 202# @USAGE: <USE flag> [flag name]
65# @DESCRIPTION: 203# @DESCRIPTION:
66# Based on use_enable. See ebuild(5). 204# Based on use_enable. See ebuild(5).
67# 205#
68# `cmake-utils_use_want foo FOO` echoes -DWANT_FOO=ON if foo is enabled 206# `cmake-utils_use_want foo FOO` echoes -DWANT_FOO=ON if foo is enabled
69# and -DWANT_FOO=OFF if it is disabled. 207# and -DWANT_FOO=OFF if it is disabled.
70cmake-utils_use_want() { _use_me_now WANT "$@" ; } 208cmake-utils_use_want() { _use_me_now WANT_ "$@" ; }
71 209
72# @FUNCTION: cmake-utils_has 210# @FUNCTION: cmake-utils_use_build
73# @USAGE: <USE flag> [flag name] 211# @USAGE: <USE flag> [flag name]
74# @DESCRIPTION: 212# @DESCRIPTION:
75# Based on use_enable. See ebuild(5). 213# Based on use_enable. See ebuild(5).
76# 214#
215# `cmake-utils_use_build foo FOO` echoes -DBUILD_FOO=ON if foo is enabled
216# and -DBUILD_FOO=OFF if it is disabled.
217cmake-utils_use_build() { _use_me_now BUILD_ "$@" ; }
218
219# @FUNCTION: cmake-utils_use_has
220# @USAGE: <USE flag> [flag name]
221# @DESCRIPTION:
222# Based on use_enable. See ebuild(5).
223#
77# `cmake-utils_has foo FOO` echoes -DHAVE_FOO=ON if foo is enabled 224# `cmake-utils_use_has foo FOO` echoes -DHAVE_FOO=ON if foo is enabled
78# and -DHAVE_FOO=OFF if it is disabled. 225# and -DHAVE_FOO=OFF if it is disabled.
79cmake-utils_has() { _use_me_now HAVE "$@" ; } 226cmake-utils_use_has() { _use_me_now HAVE_ "$@" ; }
80 227
228# @FUNCTION: cmake-utils_use
229# @USAGE: <USE flag> [flag name]
230# @DESCRIPTION:
231# Based on use_enable. See ebuild(5).
232#
233# `cmake-utils_use foo FOO` echoes -DFOO=ON if foo is enabled
234# and -DFOO=OFF if it is disabled.
235cmake-utils_use() { _use_me_now "" "$@" ; }
236
237# Internal function for modifying hardcoded definitions.
238# Removes dangerous definitionts that override Gentoo settings.
239_modify-cmakelists() {
240 debug-print-function ${FUNCNAME} "$@"
241
242 # Comment out all set (<some_should_be_user_defined_variable> value)
243 # TODO Add QA checker - inform when variable being checked for below is set in CMakeLists.txt
244 find "${CMAKE_USE_DIR}" -name CMakeLists.txt \
245 -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_INSTALL_PREFIX.*)/{s/^/#IGNORE /g}' {} + \
247 || die "${LINENO}: failed to disable hardcoded settings"
248
249 # NOTE Append some useful summary here
250 cat >> CMakeLists.txt <<- _EOF_
251 MESSAGE(STATUS "<<< Gentoo configuration >>>
252 Build type: ${CMAKE_BUILD_TYPE}
253 Install path: ${CMAKE_INSTALL_PREFIX}\n")
254 _EOF_
255}
256
81# @FUNCTION: cmake-utils_src_configure 257# @FUNCTION: enable_cmake-utils_src_configure
82# @DESCRIPTION: 258# @DESCRIPTION:
83# General function for configuring with cmake. Default behaviour is to start an 259# General function for configuring with cmake. Default behaviour is to start an
84# out-of-source build. 260# out-of-source build.
85cmake-utils_src_configure() { 261enable_cmake-utils_src_configure() {
86 debug-print-function $FUNCNAME $* 262 debug-print-function ${FUNCNAME} "$@"
87 263
264 _check_build_dir init
265
266 # check if CMakeLists.txt exist and if no then die
267 if [[ ! -e ${CMAKE_USE_DIR}/CMakeLists.txt ]] ; then
268 eerror "I was unable to locate CMakeLists.txt under:"
269 eerror "\"${CMAKE_USE_DIR}/CMakeLists.txt\""
270 eerror "You should consider not inheriting the cmake eclass."
271 die "FATAL: Unable to find CMakeLists.txt"
272 fi
273
274 # Remove dangerous things.
275 _modify-cmakelists
276
277 # Fix xdg collision with sandbox
278 export XDG_CONFIG_HOME="${T}"
279
280 # @SEE CMAKE_BUILD_TYPE
281 if [[ ${CMAKE_BUILD_TYPE} = Gentoo ]]; then
282 # Handle release builds
88 if ! has debug ${IUSE//+} || ! use debug ; then 283 if ! has debug ${IUSE//+} || ! use debug; then
89 append-cppflags -DNDEBUG 284 append-cppflags -DNDEBUG
90 fi 285 fi
91
92 if [[ -n "${CMAKE_IN_SOURCE_BUILD}" ]]; then
93 cmake-utils_src_configurein
94 else
95 cmake-utils_src_configureout
96 fi 286 fi
97}
98 287
288 # Prepare Gentoo override rules (set valid compiler, append CPPFLAGS)
289 local build_rules=${T}/gentoo_rules.cmake
290 cat > "${build_rules}" <<- _EOF_
291 SET (CMAKE_C_COMPILER $(type -P $(tc-getCC)) CACHE FILEPATH "C compiler" FORCE)
292 SET (CMAKE_C_COMPILE_OBJECT "<CMAKE_C_COMPILER> <DEFINES> ${CPPFLAGS} <FLAGS> -o <OBJECT> -c <SOURCE>" CACHE STRING "C compile command" FORCE)
293 SET (CMAKE_CXX_COMPILER $(type -P $(tc-getCXX)) CACHE FILEPATH "C++ compiler" FORCE)
294 SET (CMAKE_CXX_COMPILE_OBJECT "<CMAKE_CXX_COMPILER> <DEFINES> ${CPPFLAGS} <FLAGS> -o <OBJECT> -c <SOURCE>" CACHE STRING "C++ compile command" FORCE)
295 _EOF_
296
297 if use prefix; then
298 cat >> "${build_rules}" <<- _EOF_
299 # in Prefix we need rpath and must ensure cmake gets our default linker path
300 # right ... except for Darwin hosts
301 IF (NOT APPLE)
302 SET (CMAKE_SKIP_RPATH OFF CACHE BOOL "" FORCE)
303 SET (CMAKE_PLATFORM_REQUIRED_RUNTIME_PATH "${EPREFIX}/usr/${CHOST}/lib/gcc;${EPREFIX}/usr/${CHOST}/lib;${EPREFIX}/usr/$(get_libdir);${EPREFIX}/$(get_libdir)"
304 CACHE STRING "" FORCE)
305 ENDIF (NOT APPLE)
306 _EOF_
307 fi
308
309 # Common configure parameters (invariants)
310 local common_config=${T}/gentoo_common_config.cmake
311 local libdir=$(get_libdir)
312 cat > "${common_config}" <<- _EOF_
313 SET (LIB_SUFFIX ${libdir/lib} CACHE STRING "library path suffix" FORCE)
314 _EOF_
315 [[ -n ${CMAKE_NO_COLOR} ]] && echo 'SET (CMAKE_COLOR_MAKEFILE OFF CACHE BOOL "pretty colors during make" FORCE)' >> "${common_config}"
316
317 # Convert mycmakeargs to an array, for backwards compatibility
318 if [[ $(declare -p mycmakeargs) != "declare -a mycmakeargs="* ]]; then
319 mycmakeargs=(${mycmakeargs})
320 fi
321
322 has "${EAPI:-0}" 0 1 2 && ! use prefix && EPREFIX=
323
324 # Common configure parameters (overridable)
325 # NOTE CMAKE_BUILD_TYPE can be only overriden via CMAKE_BUILD_TYPE eclass variable
326 # No -DCMAKE_BUILD_TYPE=xxx definitions will be in effect.
327 local cmakeargs=(
328 -C "${common_config}"
329 -DCMAKE_INSTALL_PREFIX="${PREFIX:-${EPREFIX}/usr}"
330 "${mycmakeargs[@]}"
331 -DCMAKE_BUILD_TYPE="${CMAKE_BUILD_TYPE}"
332 -DCMAKE_INSTALL_DO_STRIP=OFF
333 -DCMAKE_USER_MAKE_RULES_OVERRIDE="${build_rules}"
334 )
335
336 mkdir -p "${CMAKE_BUILD_DIR}"
337 pushd "${CMAKE_BUILD_DIR}" > /dev/null
338 debug-print "${LINENO} ${ECLASS} ${FUNCNAME}: mycmakeargs is ${cmakeargs[*]}"
339 echo cmake "${cmakeargs[@]}" "${CMAKE_USE_DIR}"
340 cmake "${cmakeargs[@]}" "${CMAKE_USE_DIR}" || die "cmake failed"
341
342 popd > /dev/null
343}
344
99# @FUNCTION: cmake-utils_src_compile 345# @FUNCTION: enable_cmake-utils_src_compile
100# @DESCRIPTION: 346# @DESCRIPTION:
101# General function for compiling with cmake. Default behaviour is to check for 347# General function for compiling with cmake. Default behaviour is to check for
102# eapi and based on it configure or only compile 348# EAPI and respectively to configure as well or just compile.
103cmake-utils_src_compile() { 349enable_cmake-utils_src_compile() {
104 case ${EAPI} in 350 debug-print-function ${FUNCNAME} "$@"
105 2)
106 ;;
107 *)
108 cmake-utils_src_configure
109 ;;
110 esac
111 351
352 has src_configure ${CMAKE_EXPF} || cmake-utils_src_configure
112 cmake-utils_src_make "$@" 353 cmake-utils_src_make "$@"
113} 354}
114 355
115# @FUNCTION: cmake-utils_src_configurein
116# @DESCRIPTION:
117# Function for software that requires configure and building in the source
118# directory.
119cmake-utils_src_configurein() {
120 debug-print-function $FUNCNAME $*
121
122 local cmakeargs="$(_common_configure_code) ${mycmakeargs} ${EXTRA_ECONF}"
123
124 debug-print "$LINENO $ECLASS $FUNCNAME: mycmakeargs is $cmakeargs"
125 cmake ${cmakeargs} . || die "Cmake failed"
126}
127
128# @FUNCTION: cmake-utils_src_configureout
129# @DESCRIPTION:
130# Function for software that requires configure and building outside the source
131# tree - default.
132cmake-utils_src_configureout() {
133 debug-print-function $FUNCNAME $*
134
135 local cmakeargs="$(_common_configure_code) ${mycmakeargs} ${EXTRA_ECONF}"
136 mkdir -p "${WORKDIR}"/${PN}_build
137 pushd "${WORKDIR}"/${PN}_build > /dev/null
138
139 debug-print "$LINENO $ECLASS $FUNCNAME: mycmakeargs is $cmakeargs"
140 cmake ${cmakeargs} "${S}" || die "Cmake failed"
141
142 popd > /dev/null
143}
144
145# Internal use only. Common configuration options for all types of builds.
146_common_configure_code() {
147 local tmp_libdir=$(get_libdir)
148 # CMAKE_BUILD_TYPE only modifies compiler flags, so set to None
149 echo -DCMAKE_BUILD_TYPE=${CMAKE_BUILD_TYPE:-None}
150 echo -DCMAKE_C_COMPILER=$(type -P $(tc-getCC))
151 echo -DCMAKE_CXX_COMPILER=$(type -P $(tc-getCXX))
152 echo -DCMAKE_INSTALL_PREFIX=${PREFIX:-/usr}
153 echo -DLIB_SUFFIX=${tmp_libdir/lib}
154 echo -DLIB_INSTALL_DIR=${PREFIX:-/usr}/${tmp_libdir}
155 [[ -n ${CMAKE_NO_COLOR} ]] && echo -DCMAKE_COLOR_MAKEFILE=OFF
156}
157
158# @FUNCTION: cmake-utils_src_make 356# @FUNCTION: cmake-utils_src_make
159# @DESCRIPTION: 357# @DESCRIPTION:
160# Function for building the package. Automatically detects the build type. 358# Function for building the package. Automatically detects the build type.
161# All arguments are passed to emake: 359# All arguments are passed to emake
162# "cmake-utils_src_make -j1" can be used to work around parallel make issues.
163cmake-utils_src_make() { 360cmake-utils_src_make() {
164 debug-print-function $FUNCNAME $* 361 debug-print-function ${FUNCNAME} "$@"
165 362
166 # At this point we can automatically check if it's an out-of-source or an 363 _check_build_dir
167 # in-source build 364 pushd "${CMAKE_BUILD_DIR}" &> /dev/null
168 if [[ -d ${WORKDIR}/${PN}_build ]]; then 365 # first check if Makefile exist otherwise die
169 pushd "${WORKDIR}"/${PN}_build > /dev/null 366 [[ -e Makefile ]] || die "Makefile not found. Error during configure stage."
170 fi
171 if ! [[ -z ${CMAKE_COMPILER_VERBOSE} ]]; then 367 if [[ -n ${CMAKE_VERBOSE} ]]; then
172 emake VERBOSE=1 "$@" || die "Make failed!" 368 emake VERBOSE=1 "$@" || die "Make failed!"
173 else 369 else
174 emake "$@" || die "Make failed!" 370 emake "$@" || die "Make failed!"
175 fi 371 fi
176 if [[ -d ${WORKDIR}/${PN}_build ]]; then
177 popd > /dev/null 372 popd &> /dev/null
178 fi
179} 373}
180 374
181# @FUNCTION: cmake-utils_src_install 375# @FUNCTION: enable_cmake-utils_src_install
182# @DESCRIPTION: 376# @DESCRIPTION:
183# Function for installing the package. Automatically detects the build type. 377# Function for installing the package. Automatically detects the build type.
184cmake-utils_src_install() { 378enable_cmake-utils_src_install() {
185 debug-print-function $FUNCNAME $* 379 debug-print-function ${FUNCNAME} "$@"
186 380
187 # At this point we can automatically check if it's an out-of-source or an 381 _check_build_dir
188 # in-source build 382 pushd "${CMAKE_BUILD_DIR}" &> /dev/null
189 if [[ -d ${WORKDIR}/${PN}_build ]]; then
190 pushd "${WORKDIR}"/${PN}_build > /dev/null
191 fi
192 emake install DESTDIR="${D}" || die "Make install failed" 383 emake install DESTDIR="${D}" || die "Make install failed"
193 if [[ -d ${WORKDIR}/${PN}_build ]]; then
194 popd > /dev/null 384 popd &> /dev/null
195 fi
196 385
197 # Manual document installation 386 # Manual document installation
198 [[ -n "${DOCS}" ]] && dodoc ${DOCS} 387 [[ -n "${DOCS}" ]] && { dodoc ${DOCS} || die "dodoc failed" ; }
388 [[ -n "${HTML_DOCS}" ]] && { dohtml -r ${HTML_DOCS} || die "dohtml failed" ; }
199} 389}
200 390
201# @FUNCTION: cmake-utils_src_test 391# @FUNCTION: enable_cmake-utils_src_test
202# @DESCRIPTION: 392# @DESCRIPTION:
203# Function for testing the package. Automatically detects the build type. 393# Function for testing the package. Automatically detects the build type.
204cmake-utils_src_test() { 394enable_cmake-utils_src_test() {
205 debug-print-function $FUNCNAME $* 395 debug-print-function ${FUNCNAME} "$@"
206 396
207 # At this point we can automatically check if it's an out-of-source or an 397 _check_build_dir
208 # in-source build 398 pushd "${CMAKE_BUILD_DIR}" &> /dev/null
209 if [[ -d ${WORKDIR}/${PN}_build ]]; then
210 pushd "${WORKDIR}"/${PN}_build > /dev/null
211 fi
212 # Standard implementation of src_test 399 # Standard implementation of src_test
213 if emake -j1 check -n &> /dev/null; then 400 if emake -j1 check -n &> /dev/null; then
214 einfo ">>> Test phase [check]: ${CATEGORY}/${PF}" 401 einfo ">>> Test phase [check]: ${CATEGORY}/${PF}"
215 if ! emake -j1 check; then 402 if ! emake -j1 check; then
216 die "Make check failed. See above for details." 403 die "Make check failed. See above for details."
221 die "Make test failed. See above for details." 408 die "Make test failed. See above for details."
222 fi 409 fi
223 else 410 else
224 einfo ">>> Test phase [none]: ${CATEGORY}/${PF}" 411 einfo ">>> Test phase [none]: ${CATEGORY}/${PF}"
225 fi 412 fi
226 if [[ -d ${WORKDIR}/${PN}_build ]]; then
227 popd > /dev/null 413 popd &> /dev/null
228 fi
229} 414}
415
416## Wrappers for calls bellow this line
417# @FUNCTION: cmake-utils_src_configure
418# @DESCRIPTION:
419# Wrapper for detection if we want to run enable_ prefixed function with same name
420# unconditionaly or only when some useflag is enabled.
421cmake-utils_src_configure() {
422 _execute_optionaly "src_configure"
423}
424
425# @FUNCTION: cmake-utils_src_compile
426# @DESCRIPTION:
427# Wrapper for detection if we want to run enable_ prefixed function with same name
428# unconditionaly or only when some useflag is enabled.
429cmake-utils_src_compile() {
430 _execute_optionaly "src_compile"
431}
432
433# @FUNCTION: cmake-utils_src_install
434# @DESCRIPTION:
435# Wrapper for detection if we want to run enable_ prefixed function with same name
436# unconditionaly or only when some useflag is enabled.
437cmake-utils_src_install() {
438 _execute_optionaly "src_install"
439}
440
441# @FUNCTION: cmake-utils_src_test
442# @DESCRIPTION:
443# Wrapper for detection if we want to run enable_ prefixed function with same name
444# unconditionaly or only when some useflag is enabled.
445cmake-utils_src_test() {
446 _execute_optionaly "src_test"
447}
448
449
450_execute_optionaly() {
451 local phase="$1"
452 if [[ ${WANT_CMAKE} = always ]]; then
453 enable_cmake-utils_${phase}
454 else
455 use ${WANT_CMAKE} && enable_cmake-utils_${phase}
456 fi
457}

Legend:
Removed from v.1.13  
changed lines
  Added in v.1.35

  ViewVC Help
Powered by ViewVC 1.1.20