# Copyright 1999-2018 Gentoo Foundation # Distributed under the terms of the GNU General Public License v2 # @ECLASS: ninja-utils.eclass # @MAINTAINER: # Michał Górny <mgorny@gentoo.org> # Mike Gilbert <floppym@gentoo.org> # @AUTHOR: # Michał Górny <mgorny@gentoo.org> # Mike Gilbert <floppym@gentoo.org> # @SUPPORTED_EAPIS: 2 4 5 6 7 # @BLURB: common bits to run dev-util/ninja builder # @DESCRIPTION: # This eclass provides a single function -- eninja -- that can be used # to run the ninja builder alike emake. It does not define any # dependencies, you need to depend on dev-util/ninja yourself. Since # ninja is rarely used stand-alone, most of the time this eclass will # be used indirectly by the eclasses for other build systems (CMake, # Meson). if [[ -z ${_NINJA_UTILS_ECLASS} ]]; then case ${EAPI:-0} in 0|1|3) die "EAPI=${EAPI:-0} is not supported (too old)";; # copied from cmake-utils 2|4|5|6|7) ;; *) die "EAPI=${EAPI} is not yet supported" ;; esac # @ECLASS-VARIABLE: NINJAOPTS # @DEFAULT_UNSET # @DESCRIPTION: # The default set of options to pass to Ninja. Similar to MAKEOPTS, # supposed to be set in make.conf. If unset, eninja() will convert # MAKEOPTS instead. inherit multiprocessing # @FUNCTION: eninja # @USAGE: [<args>...] # @DESCRIPTION: # Call Ninja, passing the NINJAOPTS (or converted MAKEOPTS), followed # by the supplied arguments. This function dies if ninja fails. Starting # with EAPI 6, it also supports being called via 'nonfatal'. eninja() { local nonfatal_args=() [[ ${EAPI:-0} != [245] ]] && nonfatal_args+=( -n ) if [[ -z ${NINJAOPTS+set} ]]; then NINJAOPTS="-j$(makeopts_jobs) -l$(makeopts_loadavg "${MAKEOPTS}" 0)" fi set -- ninja -v ${NINJAOPTS} "$@" echo "$@" >&2 "$@" || die "${nonfatal_args[@]}" "${*} failed" } _NINJA_UTILS_ECLASS=1 fi