xbps-src: install binpkgdeps sequentially, to know which one failed.
This commit is contained in:
parent
87c7b81d9b
commit
784c44b359
1 changed files with 16 additions and 75 deletions
|
@ -23,63 +23,20 @@
|
||||||
# THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
# THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
||||||
#-
|
#-
|
||||||
|
|
||||||
#
|
|
||||||
# Install all required package dependencies in one pass, like:
|
|
||||||
#
|
|
||||||
# xbps-bin install "foo>=0" "blah<=0" "..."
|
|
||||||
#
|
|
||||||
install_pkglist_from_repos()
|
|
||||||
{
|
|
||||||
local cmd rval depstmpf tmplogf
|
|
||||||
|
|
||||||
cmd="${fakeroot_cmd} ${fakeroot_cmd_args} ${XBPS_BIN_CMD} -Ay install"
|
|
||||||
|
|
||||||
msg_normal "$pkgver: installing required dependencies ...\n"
|
|
||||||
|
|
||||||
depstmpf=$(mktemp)
|
|
||||||
for f in ${1}; do
|
|
||||||
echo "'${f}' " >> $depstmpf
|
|
||||||
done
|
|
||||||
tmplogf=$(mktemp)
|
|
||||||
${cmd} $(cat $depstmpf) >$tmplogf 2>&1
|
|
||||||
rval=$?
|
|
||||||
rm -f $depstmpf
|
|
||||||
|
|
||||||
if [ $rval -ne 0 -a $rval -ne 6 ]; then
|
|
||||||
# xbps-bin can return:
|
|
||||||
#
|
|
||||||
# SUCCESS (0): package installed successfully.
|
|
||||||
# ENOENT (2): package missing in repositories.
|
|
||||||
# EEXIST (6): package already installed.
|
|
||||||
# ENODEV (19): package depends on missing dependencies.
|
|
||||||
#
|
|
||||||
# Any other error returned is critical.
|
|
||||||
autoremove_pkg_dependencies $KEEP_AUTODEPS
|
|
||||||
msg_red "$pkgver: failed to install required dependencies! (error $rval)\n"
|
|
||||||
cat $tmplogf && rm -f $tmplogf
|
|
||||||
msg_error "Please see above for the real error, exiting...\n"
|
|
||||||
fi
|
|
||||||
rm -f $tmplogf
|
|
||||||
|
|
||||||
return $rval
|
|
||||||
}
|
|
||||||
|
|
||||||
#
|
#
|
||||||
# Install a required package dependency, like:
|
# Install a required package dependency, like:
|
||||||
#
|
#
|
||||||
# xbps-bin install "foo>=0"
|
# xbps-bin -Ay install "pattern"
|
||||||
#
|
#
|
||||||
install_pkg_from_repos()
|
install_pkg_from_repos()
|
||||||
{
|
{
|
||||||
local cmd rval pkgdepname tmplogf pkg="$1"
|
local cmd rval tmplogf
|
||||||
|
|
||||||
|
msg_normal "$pkgver: installing dependency $1 ...\n"
|
||||||
|
|
||||||
pkgdepname=$($XBPS_PKGDB_CMD getpkgdepname "$pkg")
|
|
||||||
cmd="${fakeroot_cmd} ${fakeroot_cmd_args} ${XBPS_BIN_CMD} -Ay install"
|
cmd="${fakeroot_cmd} ${fakeroot_cmd_args} ${XBPS_BIN_CMD} -Ay install"
|
||||||
|
|
||||||
msg_normal "$pkgver: installing required dependency '$pkg' ...\n"
|
|
||||||
|
|
||||||
tmplogf=$(mktemp)
|
tmplogf=$(mktemp)
|
||||||
${cmd} "${pkg}" >${tmplogf} 2>&1
|
${cmd} ${1} >${tmplogf} 2>&1
|
||||||
rval=$?
|
rval=$?
|
||||||
if [ $rval -ne 0 -a $rval -ne 6 ]; then
|
if [ $rval -ne 0 -a $rval -ne 6 ]; then
|
||||||
# xbps-bin can return:
|
# xbps-bin can return:
|
||||||
|
@ -91,7 +48,7 @@ install_pkg_from_repos()
|
||||||
#
|
#
|
||||||
# Any other error returned is critical.
|
# Any other error returned is critical.
|
||||||
autoremove_pkg_dependencies $KEEP_AUTODEPS
|
autoremove_pkg_dependencies $KEEP_AUTODEPS
|
||||||
msg_red "$pkgver: failed to install '${pkg}' dependency! (error $rval)\n"
|
msg_red "$pkgver: failed to install '$1' dependency! (error $rval)\n"
|
||||||
cat $tmplogf && rm -f $tmplogf
|
cat $tmplogf && rm -f $tmplogf
|
||||||
msg_error "Please see above for the real error, exiting...\n"
|
msg_error "Please see above for the real error, exiting...\n"
|
||||||
fi
|
fi
|
||||||
|
@ -189,7 +146,7 @@ install_pkg_deps()
|
||||||
|
|
||||||
prev_pkg="$j"
|
prev_pkg="$j"
|
||||||
if [ -n "$XBPS_PREFER_BINPKG_DEPS" -a -z "$bootstrap" ]; then
|
if [ -n "$XBPS_PREFER_BINPKG_DEPS" -a -z "$bootstrap" ]; then
|
||||||
install_pkg_from_repos "${j}"
|
install_pkg_from_repos \"${j}\"
|
||||||
if [ $? -eq 255 ]; then
|
if [ $? -eq 255 ]; then
|
||||||
# xbps-bin returned unexpected error
|
# xbps-bin returned unexpected error
|
||||||
msg_red "$saved_prevpkg: failed to install dependency '$j'\n"
|
msg_red "$saved_prevpkg: failed to install dependency '$j'\n"
|
||||||
|
@ -215,7 +172,7 @@ install_pkg_deps()
|
||||||
done
|
done
|
||||||
|
|
||||||
if [ -n "$XBPS_PREFER_BINPKG_DEPS" -a -z "$bootstrap" ]; then
|
if [ -n "$XBPS_PREFER_BINPKG_DEPS" -a -z "$bootstrap" ]; then
|
||||||
install_pkg_from_repos "${curpkg}"
|
install_pkg_from_repos \"${curpkg}\"
|
||||||
if [ $? -eq 255 ]; then
|
if [ $? -eq 255 ]; then
|
||||||
# xbps-bin returned unexpected error
|
# xbps-bin returned unexpected error
|
||||||
return $?
|
return $?
|
||||||
|
@ -248,8 +205,7 @@ install_pkg_deps()
|
||||||
install_dependencies_pkg()
|
install_dependencies_pkg()
|
||||||
{
|
{
|
||||||
local pkg="$1"
|
local pkg="$1"
|
||||||
local lpkgname=$(${XBPS_PKGDB_CMD} getpkgname ${pkg})
|
local i pkgn iver missing_deps
|
||||||
local rval i j pkgn iver reqver notinstalled_deps pkglist pkgcount
|
|
||||||
|
|
||||||
[ -z "$pkg" ] && return 2
|
[ -z "$pkg" ] && return 2
|
||||||
[ -z "$build_depends" ] && return 0
|
[ -z "$build_depends" ] && return 0
|
||||||
|
@ -266,39 +222,24 @@ install_dependencies_pkg()
|
||||||
echo " ${i}: found '$pkgn-$iver'."
|
echo " ${i}: found '$pkgn-$iver'."
|
||||||
else
|
else
|
||||||
echo " ${i}: not found."
|
echo " ${i}: not found."
|
||||||
notinstalled_deps="${notinstalled_deps} ${i}"
|
missing_deps=1
|
||||||
fi
|
fi
|
||||||
done
|
done
|
||||||
|
|
||||||
[ -z "$notinstalled_deps" ] && return 0
|
[ -z "$missing_deps" ] && return 0
|
||||||
|
|
||||||
# Install direct build dependencies from binary packages.
|
# Install direct build dependencies from binary packages.
|
||||||
if [ -n "$XBPS_PREFER_BINPKG_DEPS" -a -z "$bootstrap" ]; then
|
if [ -n "$XBPS_PREFER_BINPKG_DEPS" -a -z "$bootstrap" ]; then
|
||||||
msg_normal "$pkgver: installing dependencies from repositories ...\n"
|
msg_normal "$pkgver: installing dependencies from repositories ...\n"
|
||||||
pkgcount=0
|
for i in ${build_depends}; do
|
||||||
for i in ${notinstalled_deps}; do
|
install_pkg_from_repos \"${i}\"
|
||||||
if [ -z "$pkglist" ]; then
|
|
||||||
pkgcount=1
|
|
||||||
pkglist="${i}"
|
|
||||||
else
|
|
||||||
pkglist="${pkglist} ${i}"
|
|
||||||
pkgcount=$(($pkgcount + 1))
|
|
||||||
fi
|
|
||||||
done
|
done
|
||||||
if [ "$pkgcount" -eq 1 ]; then
|
return 0
|
||||||
install_pkg_from_repos "${pkglist}"
|
|
||||||
else
|
|
||||||
install_pkglist_from_repos "${pkglist}"
|
|
||||||
fi
|
|
||||||
if [ $? -eq 0 ]; then
|
|
||||||
# Install successfully
|
|
||||||
return 0
|
|
||||||
fi
|
|
||||||
fi
|
fi
|
||||||
|
|
||||||
# Install direct and indirect build dependencies from source.
|
# Install direct and indirect build dependencies from source.
|
||||||
for j in ${notinstalled_deps}; do
|
for i in ${build_depends}; do
|
||||||
install_pkg_deps "${j}" "${pkg}"
|
install_pkg_deps "${i}" "${pkg}"
|
||||||
if [ $? -eq 1 ]; then
|
if [ $? -eq 1 ]; then
|
||||||
return 1
|
return 1
|
||||||
fi
|
fi
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue