849d22e46d
The build.sh script is now responsible to handle all the logic to build a source package and its subpackages, as well as all its required build dependencies. Thanks to this and subshells, dependencies are now built into its own child process, creating a process tree that can go nested as long as your system allows forking and has enough memory :-) This fixes some issues that have been while building pkgs that have lots of nested dependencies.
62 lines
1.2 KiB
Bash
Executable File
62 lines
1.2 KiB
Bash
Executable File
#!/bin/bash
|
|
#
|
|
# vim: set ts=4 sw=4 et:
|
|
#
|
|
# Passed arguments:
|
|
# $1 - pkgname [REQUIRED]
|
|
# $2 - cross target [OPTIONAL]
|
|
|
|
if [ $# -lt 1 -o $# -gt 2 ]; then
|
|
echo "$(basename $0): invalid number of arguments: pkgname [cross-target]"
|
|
exit 1
|
|
fi
|
|
|
|
PKGNAME="$1"
|
|
XBPS_CROSS_BUILD="$2"
|
|
|
|
for f in $XBPS_SHUTILSDIR/*.sh; do
|
|
. $f
|
|
done
|
|
|
|
setup_pkg "$PKGNAME" $XBPS_CROSS_BUILD
|
|
|
|
for f in $XBPS_COMMONDIR/environment/fetch/*.sh; do
|
|
source_file "$f"
|
|
done
|
|
|
|
XBPS_FETCH_DONE="${XBPS_STATEDIR}/${sourcepkg}_${XBPS_CROSS_BUILD}_fetch_done"
|
|
|
|
if [ -f "$XBPS_FETCH_DONE" ]; then
|
|
exit 0
|
|
fi
|
|
|
|
# Run pre-fetch hooks.
|
|
run_pkg_hooks pre-fetch
|
|
|
|
# If template defines pre_fetch(), use it.
|
|
if declare -f pre_fetch >/dev/null; then
|
|
run_func pre_fetch
|
|
fi
|
|
|
|
# If template defines do_fetch(), use it rather than the hooks.
|
|
if declare -f do_fetch >/dev/null; then
|
|
cd ${XBPS_BUILDDIR}
|
|
[ -n "$build_wrksrc" ] && mkdir -p "$wrksrc"
|
|
run_func do_fetch
|
|
else
|
|
# Run do-fetch hooks.
|
|
run_pkg_hooks "do-fetch"
|
|
fi
|
|
|
|
# if templates defines post_fetch(), use it.
|
|
if declare -f post_fetch >/dev/null; then
|
|
run_func post_fetch
|
|
fi
|
|
|
|
# Run post-fetch hooks.
|
|
run_pkg_hooks post-fetch
|
|
|
|
touch -f $XBPS_FETCH_DONE
|
|
|
|
exit 0
|