"Robin H. Johnson" writes: > 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 > LGTM, but give a bit of time for other comments. > Signed-off-by: Robin H. Johnson > --- > 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 > }