Improve how build deps are processed, return on errors immediately.
This commit is contained in:
parent
15b6f5be38
commit
e675201990
3 changed files with 83 additions and 27 deletions
|
@ -64,7 +64,7 @@ install_src_phase()
|
||||||
{
|
{
|
||||||
local f i subpkg lver spkgrev saved_wrksrc
|
local f i subpkg lver spkgrev saved_wrksrc
|
||||||
|
|
||||||
[ -z $pkgname ] && return 1
|
[ -z $pkgname ] && return 2
|
||||||
|
|
||||||
if [ -n "$revision" ]; then
|
if [ -n "$revision" ]; then
|
||||||
lver="${version}_${revision}"
|
lver="${version}_${revision}"
|
||||||
|
@ -205,9 +205,9 @@ make_install()
|
||||||
|| msg_error "$pkgname: make install failed!"
|
|| msg_error "$pkgname: make install failed!"
|
||||||
}
|
}
|
||||||
|
|
||||||
[ -z "$PKG_TMPLNAME" ] && exit 1
|
[ -z "$PKG_TMPLNAME" ] && exit 2
|
||||||
|
|
||||||
setup_tmpl $PKG_TMPLNAME
|
setup_tmpl $PKG_TMPLNAME
|
||||||
install_src_phase $pkgname
|
install_src_phase $pkgname
|
||||||
|
|
||||||
exit $?
|
exit 0
|
||||||
|
|
|
@ -36,7 +36,7 @@ install_pkg_deps()
|
||||||
local saved_prevpkg="$(${XBPS_PKGDB_CMD} getpkgdepname $2)"
|
local saved_prevpkg="$(${XBPS_PKGDB_CMD} getpkgdepname $2)"
|
||||||
local j jver jname reqver
|
local j jver jname reqver
|
||||||
|
|
||||||
[ -z "$curpkg" ] && return 1
|
[ -z "$curpkg" -o -z "$curpkgname" ] && return 2
|
||||||
|
|
||||||
if [ -n "$prev_pkg" ]; then
|
if [ -n "$prev_pkg" ]; then
|
||||||
curpkg=$prev_pkg
|
curpkg=$prev_pkg
|
||||||
|
@ -45,7 +45,7 @@ install_pkg_deps()
|
||||||
|
|
||||||
msg_normal "Installing $saved_prevpkg dependency: $curpkgname."
|
msg_normal "Installing $saved_prevpkg dependency: $curpkgname."
|
||||||
|
|
||||||
setup_tmpl $curpkgname
|
setup_tmpl "$curpkgname"
|
||||||
check_build_depends_pkg
|
check_build_depends_pkg
|
||||||
if [ $? -eq 0 ]; then
|
if [ $? -eq 0 ]; then
|
||||||
msg_normal "Dependency $curpkgname requires:"
|
msg_normal "Dependency $curpkgname requires:"
|
||||||
|
@ -68,13 +68,16 @@ install_pkg_deps()
|
||||||
check_pkgdep_matched "${j}"
|
check_pkgdep_matched "${j}"
|
||||||
[ $? -eq 0 ] && continue
|
[ $? -eq 0 ] && continue
|
||||||
|
|
||||||
[ -n "$prev_pkg" ] && unset prev_pkg
|
|
||||||
#
|
#
|
||||||
# Iterate again, this will check if there are more
|
# Iterate again, this will check if there are more
|
||||||
# required deps for current pkg.
|
# required deps for current pkg.
|
||||||
#
|
#
|
||||||
install_pkg_deps $j $curpkg
|
|
||||||
prev_pkg="$j"
|
prev_pkg="$j"
|
||||||
|
install_pkg_deps "${j}" "${curpkg}"
|
||||||
|
if [ $? -eq 1 ]; then
|
||||||
|
msg_red "install_pkg_deps: cannot install '$curpkg' ($j)."
|
||||||
|
return 1
|
||||||
|
fi
|
||||||
done
|
done
|
||||||
|
|
||||||
if [ -n "$XBPS_PREFER_BINPKG_DEPS" ]; then
|
if [ -n "$XBPS_PREFER_BINPKG_DEPS" ]; then
|
||||||
|
@ -84,12 +87,25 @@ install_pkg_deps()
|
||||||
return $?
|
return $?
|
||||||
elif [ $? -eq 1 ]; then
|
elif [ $? -eq 1 ]; then
|
||||||
# Package not found, build from source.
|
# Package not found, build from source.
|
||||||
install_pkg $curpkgname || return $?
|
install_pkg "${curpkgname}"
|
||||||
|
if [ $? -eq 1 ]; then
|
||||||
|
msg_red "cannot install '$curpkgname'!"
|
||||||
|
return 1
|
||||||
|
fi
|
||||||
fi
|
fi
|
||||||
else
|
else
|
||||||
install_pkg $curpkgname
|
if [ -n "$saved_prevpkg" ]; then
|
||||||
|
msg_normal "Installing ${curpkgname} required by ${saved_prevpkg}."
|
||||||
|
else
|
||||||
|
msg_normal "Installing ${curpkgname}."
|
||||||
|
fi
|
||||||
|
install_pkg "${curpkgname}"
|
||||||
|
if [ $? -eq 1 ]; then
|
||||||
|
msg_red "install_pkg_deps: cannot install '$curpkgname'!"
|
||||||
|
return 1
|
||||||
|
fi
|
||||||
fi
|
fi
|
||||||
[ -n "$prev_pkg" ] && unset prev_pkg
|
unset prev_pkg
|
||||||
}
|
}
|
||||||
|
|
||||||
#
|
#
|
||||||
|
@ -99,9 +115,9 @@ install_dependencies_pkg()
|
||||||
{
|
{
|
||||||
local pkg="$1" rval pkgdep_list
|
local pkg="$1" rval pkgdep_list
|
||||||
local lpkgname=$(${XBPS_PKGDB_CMD} getpkgname ${pkg})
|
local lpkgname=$(${XBPS_PKGDB_CMD} getpkgname ${pkg})
|
||||||
local i pkgn iver reqver notinstalled_deps lver
|
local i j pkgn iver reqver notinstalled_deps lver
|
||||||
|
|
||||||
[ -z "$pkg" ] && return 1
|
[ -z "$pkg" ] && return 2
|
||||||
|
|
||||||
doing_deps=true
|
doing_deps=true
|
||||||
|
|
||||||
|
@ -147,9 +163,9 @@ install_dependencies_pkg()
|
||||||
fi
|
fi
|
||||||
fi
|
fi
|
||||||
|
|
||||||
for i in ${notinstalled_deps}; do
|
for j in ${notinstalled_deps}; do
|
||||||
if [ -n "$XBPS_PREFER_BINPKG_DEPS" ]; then
|
if [ -n "$XBPS_PREFER_BINPKG_DEPS" ]; then
|
||||||
install_pkg_with_binpkg "${i}"
|
install_pkg_with_binpkg "${j}"
|
||||||
rval=$?
|
rval=$?
|
||||||
if [ $rval -eq 255 ]; then
|
if [ $rval -eq 255 ]; then
|
||||||
# xbps-bin returned unexpected error (-1)
|
# xbps-bin returned unexpected error (-1)
|
||||||
|
@ -159,16 +175,16 @@ install_dependencies_pkg()
|
||||||
continue
|
continue
|
||||||
fi
|
fi
|
||||||
fi
|
fi
|
||||||
pkgn=$($XBPS_PKGDB_CMD getpkgdepname ${i})
|
pkgn=$($XBPS_PKGDB_CMD getpkgdepname ${j})
|
||||||
check_pkgdep_matched "${i}"
|
check_pkgdep_matched "${j}"
|
||||||
[ $? -eq 0 ] && continue
|
[ $? -eq 0 ] && continue
|
||||||
|
|
||||||
setup_tmpl $pkgn
|
setup_tmpl "$pkgn"
|
||||||
check_build_depends_pkg
|
check_build_depends_pkg
|
||||||
if [ $? -eq 1 ]; then
|
if [ $? -eq 1 ]; then
|
||||||
msg_normal "Installing $lpkgname dependency: $pkgn."
|
msg_normal "Installing $lpkgname dependency: $pkgn."
|
||||||
if [ -n "$XBPS_PREFER_BINPKG_DEPS" ]; then
|
if [ -n "$XBPS_PREFER_BINPKG_DEPS" ]; then
|
||||||
install_pkg_with_binpkg "${i}"
|
install_pkg_with_binpkg "${j}"
|
||||||
rval=$?
|
rval=$?
|
||||||
if [ $rval -eq 255 ]; then
|
if [ $rval -eq 255 ]; then
|
||||||
# xbps-bin returned unexpected error
|
# xbps-bin returned unexpected error
|
||||||
|
@ -178,13 +194,25 @@ install_dependencies_pkg()
|
||||||
continue
|
continue
|
||||||
else
|
else
|
||||||
# package not found, build source.
|
# package not found, build source.
|
||||||
install_pkg $pkgn || return $?
|
install_pkg "${pkgn}"
|
||||||
|
if [ $? -eq 1 ]; then
|
||||||
|
msg_red "cannot install '$pkgn'!"
|
||||||
|
return 1
|
||||||
|
fi
|
||||||
fi
|
fi
|
||||||
else
|
else
|
||||||
install_pkg $pkgn
|
install_pkg "${pkgn}"
|
||||||
|
if [ $? -eq 1 ]; then
|
||||||
|
msg_red "cannot install '$pkgn'!"
|
||||||
|
return 1
|
||||||
|
fi
|
||||||
fi
|
fi
|
||||||
else
|
else
|
||||||
install_pkg_deps "${i}" $pkg
|
install_pkg_deps "${j}" "${pkg}"
|
||||||
|
if [ $? -eq 1 ]; then
|
||||||
|
msg_red "install_dependencies_pkg: cannot install pkgdeps required by $pkg ($j)."
|
||||||
|
return 1
|
||||||
|
fi
|
||||||
fi
|
fi
|
||||||
done
|
done
|
||||||
}
|
}
|
||||||
|
|
|
@ -65,6 +65,10 @@ install_pkg()
|
||||||
#
|
#
|
||||||
if [ -z "$doing_deps" ]; then
|
if [ -z "$doing_deps" ]; then
|
||||||
install_dependencies_pkg $pkg
|
install_dependencies_pkg $pkg
|
||||||
|
if [ $? -eq 1 ]; then
|
||||||
|
msg_red "cannot install pkgdeps for '$pkg'!"
|
||||||
|
return 1
|
||||||
|
fi
|
||||||
#
|
#
|
||||||
# At this point all required deps are installed, and
|
# At this point all required deps are installed, and
|
||||||
# only remaining is the origin package; install it.
|
# only remaining is the origin package; install it.
|
||||||
|
@ -81,17 +85,29 @@ install_pkg()
|
||||||
|
|
||||||
if [ ! -f "$XBPS_EXTRACT_DONE" ]; then
|
if [ ! -f "$XBPS_EXTRACT_DONE" ]; then
|
||||||
. $XBPS_SHUTILSDIR/extract_funcs.sh
|
. $XBPS_SHUTILSDIR/extract_funcs.sh
|
||||||
extract_distfiles || return $?
|
extract_distfiles
|
||||||
|
if [ $? -ne 0 ]; then
|
||||||
|
msg_red "cannot extract distfiles for '$pkgname'!"
|
||||||
|
return 1
|
||||||
|
fi
|
||||||
fi
|
fi
|
||||||
|
|
||||||
if [ ! -f "$XBPS_CONFIGURE_DONE" ]; then
|
if [ ! -f "$XBPS_CONFIGURE_DONE" ]; then
|
||||||
. $XBPS_SHUTILSDIR/configure_funcs.sh
|
. $XBPS_SHUTILSDIR/configure_funcs.sh
|
||||||
configure_src_phase || return $?
|
configure_src_phase
|
||||||
|
if [ $? -ne 0 ]; then
|
||||||
|
msg_red "cannot configure '$pkgname'!"
|
||||||
|
return 1
|
||||||
|
fi
|
||||||
fi
|
fi
|
||||||
|
|
||||||
if [ ! -f "$XBPS_BUILD_DONE" ]; then
|
if [ ! -f "$XBPS_BUILD_DONE" ]; then
|
||||||
. $XBPS_SHUTILSDIR/build_funcs.sh
|
. $XBPS_SHUTILSDIR/build_funcs.sh
|
||||||
build_src_phase || return $?
|
build_src_phase
|
||||||
|
if [ $? -ne 0 ]; then
|
||||||
|
msg_red "cannot build '$pkgname'!"
|
||||||
|
return 1
|
||||||
|
fi
|
||||||
fi
|
fi
|
||||||
|
|
||||||
# Install pkg into destdir.
|
# Install pkg into destdir.
|
||||||
|
@ -100,18 +116,30 @@ install_pkg()
|
||||||
dontrm_builddir=${dontrm_builddir} wrksrc=${wrksrc} \
|
dontrm_builddir=${dontrm_builddir} wrksrc=${wrksrc} \
|
||||||
${fakeroot_cmd} ${fakeroot_cmd_args} \
|
${fakeroot_cmd} ${fakeroot_cmd_args} \
|
||||||
@@XBPS_INSTALL_LIBEXECDIR@@/xbps-src-doinst-helper \
|
@@XBPS_INSTALL_LIBEXECDIR@@/xbps-src-doinst-helper \
|
||||||
${curpkgn} || return $?
|
${curpkgn}
|
||||||
|
if [ $? -ne 0 ]; then
|
||||||
|
msg_red "xbps-src-doinst-helper failed for '$pkgname'!"
|
||||||
|
return 1
|
||||||
|
fi
|
||||||
unset_build_vars
|
unset_build_vars
|
||||||
|
|
||||||
# Always write metadata to package's destdir.
|
# Always write metadata to package's destdir.
|
||||||
. $XBPS_SHUTILSDIR/metadata.sh
|
. $XBPS_SHUTILSDIR/metadata.sh
|
||||||
xbps_write_metadata_pkg || return $?
|
xbps_write_metadata_pkg
|
||||||
|
if [ $? -ne 0 ]; then
|
||||||
|
msg_red "cannot write package metadata for '$pkgname'!"
|
||||||
|
return 1
|
||||||
|
fi
|
||||||
|
|
||||||
[ "$install_destdir_target" = "yes" ] && return 0
|
[ "$install_destdir_target" = "yes" ] && return 0
|
||||||
|
|
||||||
# Stow package into masterdir.
|
# Stow package into masterdir.
|
||||||
. $XBPS_SHUTILSDIR/stow_funcs.sh
|
. $XBPS_SHUTILSDIR/stow_funcs.sh
|
||||||
stow_pkg_handler stow || return $?
|
stow_pkg_handler stow
|
||||||
|
if [ $? -ne 0 ]; then
|
||||||
|
msg_red "cannot stow '$pkgname'!"
|
||||||
|
return 1
|
||||||
|
fi
|
||||||
}
|
}
|
||||||
|
|
||||||
#
|
#
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue