Allow checking more disk space, for users with many split volumes and ever-larger packages.
gentoo-kernel-bin: / >=350MB/version (in /lib/modules) /boot >=40MB/version rust-bin: /opt >=450MB/version Signed-off-by: Robin H. Johnson <robb...@gentoo.org> --- eclass/check-reqs.eclass | 44 +++++++++++++++++++++++++++++++++++++++- 1 file changed, 43 insertions(+), 1 deletion(-) diff --git a/eclass/check-reqs.eclass b/eclass/check-reqs.eclass index fac2f4553d74..7b65f44e8c41 100644 --- a/eclass/check-reqs.eclass +++ b/eclass/check-reqs.eclass @@ -24,12 +24,21 @@ # # need this much temporary build space # CHECKREQS_DISK_BUILD="2G" # +# # install will need this much space in / +# CHECKREQS_DISK_ROOT="1G" +# +# # install will need this much space in /boot +# CHECKREQS_DISK_BOOT="128M" +# # # install will need this much space in /usr # CHECKREQS_DISK_USR="1G" # # # install will need this much space in /var # CHECKREQS_DISK_VAR="1024M" # +# # install will need this much space in /opt +# CHECKREQS_DISK_OPT="1G" +# # @CODE # # If you don't specify a value for, say, CHECKREQS_MEMORY, then the test is not @@ -56,6 +65,16 @@ _CHECK_REQS_ECLASS=1 # @DESCRIPTION: # How much diskspace is needed to build the package? Eg.: CHECKREQS_DISK_BUILD=2T +# @ECLASS_VARIABLE: CHECKREQS_DISK_ROOT +# @DEFAULT_UNSET +# @DESCRIPTION: +# How much space in / is needed to install the package? Eg.: CHECKREQS_DISK_ROOT=1G + +# @ECLASS_VARIABLE: CHECKREQS_DISK_BOOT +# @DEFAULT_UNSET +# @DESCRIPTION: +# How much space in /boot is needed to install the package? Eg.: CHECKREQS_DISK_BOOT=128M + # @ECLASS_VARIABLE: CHECKREQS_DISK_USR # @DEFAULT_UNSET # @DESCRIPTION: @@ -66,6 +85,11 @@ _CHECK_REQS_ECLASS=1 # @DESCRIPTION: # How much space is needed in /var? Eg.: CHECKREQS_DISK_VAR=3000M +# @ECLASS_VARIABLE: CHECKREQS_DISK_OPT +# @DEFAULT_UNSET +# @DESCRIPTION: +# How much space is needed in /opt? Eg.: CHECKREQS_DISK_OPT=1G + # @ECLASS_VARIABLE: CHECKREQS_DONOTHING # @USER_VARIABLE # @DEFAULT_UNSET @@ -121,8 +145,11 @@ _check-reqs_prepare() { if [[ -z ${CHECKREQS_MEMORY} && -z ${CHECKREQS_DISK_BUILD} && + -z ${CHECKREQS_DISK_ROOT} && + -z ${CHECKREQS_DISK_BOOT} && -z ${CHECKREQS_DISK_USR} && - -z ${CHECKREQS_DISK_VAR} ]]; then + -z ${CHECKREQS_DISK_VAR} && + -z ${CHECKREQS_DISK_OPT} ]]; then eerror "Set some check-reqs eclass variables if you want to use it." eerror "If you are user and see this message file a bug against the package." die "${FUNCNAME}: check-reqs eclass called but not actually used!" @@ -161,6 +188,16 @@ _check-reqs_run() { fi if [[ ${MERGE_TYPE} != buildonly ]]; then + [[ -n ${CHECKREQS_DISK_ROOT} ]] && \ + _check-reqs_disk \ + "${EROOT%/}/" \ + "${CHECKREQS_DISK_ROOT}" + + [[ -n ${CHECKREQS_DISK_BOOT} ]] && \ + _check-reqs_disk \ + "${EROOT%/}/boot" \ + "${CHECKREQS_DISK_BOOT}" + [[ -n ${CHECKREQS_DISK_USR} ]] && \ _check-reqs_disk \ "${EROOT%/}/usr" \ @@ -170,6 +207,11 @@ _check-reqs_run() { _check-reqs_disk \ "${EROOT%/}/var" \ "${CHECKREQS_DISK_VAR}" + + [[ -n ${CHECKREQS_DISK_OPT} ]] && \ + _check-reqs_disk \ + "${EROOT%/}/opt" \ + "${CHECKREQS_DISK_OPT}" fi } -- 2.43.0