|
|
e9fa07 |
#
|
|
|
8d7a8a |
# Copyright (c) 2016, 2017, 2018, 2019, 2020, 2021, 2022, 2023 LucĂa Andrea Illanes Albornoz <lucia@luciaillanes.de>
|
|
|
e9fa07 |
# set +o errexit -o noglob -o nounset is assumed.
|
|
|
e9fa07 |
#
|
|
|
e9fa07 |
|
|
|
e9fa07 |
pkg_build() {
|
|
|
e9fa07 |
local _pb_group_name="${1}" _pb_pkg_name="${2}" _pb_restart_at="${3}" \
|
|
|
e9fa07 |
_pb_libtool="" _pb_makeflags_verbosity="" _pb_no_autoconf="" \
|
|
|
e9fa07 |
_pb_rc=0 _pb_subdir="";
|
|
|
e9fa07 |
_pb_makeflags_verbosity="${PKG_MAKEFLAGS_VERBOSITY:-none}";
|
|
|
e9fa07 |
if [ "${_pb_makeflags_verbosity}" = "none" ]; then
|
|
|
e9fa07 |
_pb_makeflags_verbosity="";
|
|
|
e9fa07 |
fi;
|
|
|
e9fa07 |
|
|
|
e9fa07 |
case "${PKG_LIBTOOL:-}" in
|
|
|
e9fa07 |
"") _pb_libtool=""; ;;
|
|
|
e9fa07 |
none) _pb_libtool=""; ;;
|
|
|
e9fa07 |
*) _pb_libtool="${PKG_LIBTOOL}"; ;;
|
|
|
e9fa07 |
esac;
|
|
|
e9fa07 |
|
|
|
e9fa07 |
if [ ! -x "${PKG_CONFIGURE:-}" ]; then
|
|
|
e9fa07 |
_pb_no_autoconf=1;
|
|
|
e9fa07 |
fi;
|
|
|
e9fa07 |
|
|
|
e9fa07 |
for _pb_subdir in ${PKG_MAKE_SUBDIRS:-:}; do
|
|
|
e9fa07 |
if [ "${_pb_subdir}" = ":" ]; then
|
|
|
e9fa07 |
_pb_subdir="";
|
|
|
e9fa07 |
fi;
|
|
|
e9fa07 |
|
|
|
e9fa07 |
if [ "${#_pb_libtool}" -gt 0 ]; then
|
|
|
e9fa07 |
export MAKE="make LIBTOOL=${_pb_libtool}";
|
|
|
e9fa07 |
fi;
|
|
|
e9fa07 |
|
|
|
e9fa07 |
# N.B. We only specify CC= here if the current package does not use GNU
|
|
|
e9fa07 |
# autoconf as it often abuses it by appending -std={gnu99,...} to it
|
|
|
e9fa07 |
# instead of amending CFLAGS.
|
|
|
1cbe20 |
if [ "${PKG_MAKEFLAGS_BUILD_LIST:+1}" = 1 ]; then
|
|
|
1cbe20 |
rtl_run_cmdlineV ":" "${PKG_MAKE}" \
|
|
|
1cbe20 |
"AR=${PKG_AR}" \
|
|
|
1cbe20 |
"${_pb_no_autoconf:+CC=${PKG_CC}}" \
|
|
|
1cbe20 |
"RANLIB=${PKG_RANLIB}" \
|
|
|
1cbe20 |
"${PKG_MAKEFLAGS_BUILD_LIST}" \
|
|
|
1cbe20 |
"${PKG_MAKEFLAGS_BUILD_EXTRA_LIST:-}" \
|
|
|
1cbe20 |
${PKG_MAKEFLAGS_PARALLELISE:-} \
|
|
|
1cbe20 |
"${PKG_CFLAGS_BUILD:+CFLAGS=${PKG_CFLAGS_BUILD}}" \
|
|
|
1cbe20 |
"${PKG_CFLAGS_BUILD_EXTRA:+CFLAGS+=${PKG_CFLAGS_BUILD_EXTRA}}" \
|
|
|
1cbe20 |
"${PKG_CPPFLAGS_BUILD:+CPPFLAGS=${PKG_CPPFLAGS_BUILD}}" \
|
|
|
1cbe20 |
"${PKG_CPPFLAGS_BUILD_EXTRA:+CPPFLAGS+=${PKG_CPPFLAGS_BUILD_EXTRA}}" \
|
|
|
1cbe20 |
"${PKG_CXXFLAGS_BUILD:+CXXFLAGS=${PKG_CXXFLAGS_BUILD}}" \
|
|
|
1cbe20 |
"${PKG_CXXFLAGS_BUILD_EXTRA:+CXXFLAGS+=${PKG_CXXFLAGS_BUILD_EXTRA}}" \
|
|
|
1cbe20 |
"${PKG_LDFLAGS_BUILD:+LDFLAGS=${PKG_LDFLAGS_BUILD}}" \
|
|
|
1cbe20 |
"${PKG_LDFLAGS_BUILD_EXTRA:+LDFLAGS+=${PKG_LDFLAGS_BUILD_EXTRA}}" \
|
|
|
1cbe20 |
"${PKG_PKG_CONFIG:+PKG_CONFIG=${PKG_PKG_CONFIG}}" \
|
|
|
1cbe20 |
"${PKG_PKG_CONFIG_LIBDIR:+PKG_CONFIG_LIBDIR=${PKG_PKG_CONFIG_LIBDIR}}" \
|
|
|
1cbe20 |
${_pb_libtool:+"LIBTOOL=${_pb_libtool}"} \
|
|
|
1cbe20 |
${_pb_makeflags_verbosity} \
|
|
|
1cbe20 |
${_pb_subdir:+-C "${_pb_subdir}"};
|
|
|
1cbe20 |
_pb_rc="${?}";
|
|
|
1cbe20 |
elif [ "${PKG_MAKEFLAGS_BUILD_EXTRA_LIST:+1}" = 1 ]; then
|
|
|
1cbe20 |
rtl_run_cmdlineV ":" "${PKG_MAKE}" \
|
|
|
1cbe20 |
"AR=${PKG_AR}" \
|
|
|
1cbe20 |
"${_pb_no_autoconf:+CC=${PKG_CC}}" \
|
|
|
1cbe20 |
"RANLIB=${PKG_RANLIB}" \
|
|
|
1cbe20 |
${PKG_MAKEFLAGS_BUILD:-} \
|
|
|
1cbe20 |
"${PKG_MAKEFLAGS_BUILD_EXTRA_LIST}" \
|
|
|
1cbe20 |
${PKG_MAKEFLAGS_PARALLELISE:-} \
|
|
|
1cbe20 |
"${PKG_CFLAGS_BUILD:+CFLAGS=${PKG_CFLAGS_BUILD}}" \
|
|
|
1cbe20 |
"${PKG_CFLAGS_BUILD_EXTRA:+CFLAGS+=${PKG_CFLAGS_BUILD_EXTRA}}" \
|
|
|
1cbe20 |
"${PKG_CPPFLAGS_BUILD:+CPPFLAGS=${PKG_CPPFLAGS_BUILD}}" \
|
|
|
1cbe20 |
"${PKG_CPPFLAGS_BUILD_EXTRA:+CPPFLAGS+=${PKG_CPPFLAGS_BUILD_EXTRA}}" \
|
|
|
1cbe20 |
"${PKG_CXXFLAGS_BUILD:+CXXFLAGS=${PKG_CXXFLAGS_BUILD}}" \
|
|
|
1cbe20 |
"${PKG_CXXFLAGS_BUILD_EXTRA:+CXXFLAGS+=${PKG_CXXFLAGS_BUILD_EXTRA}}" \
|
|
|
1cbe20 |
"${PKG_LDFLAGS_BUILD:+LDFLAGS=${PKG_LDFLAGS_BUILD}}" \
|
|
|
1cbe20 |
"${PKG_LDFLAGS_BUILD_EXTRA:+LDFLAGS+=${PKG_LDFLAGS_BUILD_EXTRA}}" \
|
|
|
1cbe20 |
"${PKG_PKG_CONFIG:+PKG_CONFIG=${PKG_PKG_CONFIG}}" \
|
|
|
1cbe20 |
"${PKG_PKG_CONFIG_LIBDIR:+PKG_CONFIG_LIBDIR=${PKG_PKG_CONFIG_LIBDIR}}" \
|
|
|
1cbe20 |
${_pb_libtool:+"LIBTOOL=${_pb_libtool}"} \
|
|
|
1cbe20 |
${_pb_makeflags_verbosity} \
|
|
|
1cbe20 |
${_pb_subdir:+-C "${_pb_subdir}"};
|
|
|
1cbe20 |
_pb_rc="${?}";
|
|
|
1cbe20 |
else
|
|
|
1cbe20 |
rtl_run_cmdlineV ":" "${PKG_MAKE}" \
|
|
|
1cbe20 |
"AR=${PKG_AR}" \
|
|
|
1cbe20 |
"${_pb_no_autoconf:+CC=${PKG_CC}}" \
|
|
|
1cbe20 |
"RANLIB=${PKG_RANLIB}" \
|
|
|
1cbe20 |
${PKG_MAKEFLAGS_BUILD:-} \
|
|
|
1cbe20 |
${PKG_MAKEFLAGS_BUILD_EXTRA:-} \
|
|
|
1cbe20 |
${PKG_MAKEFLAGS_PARALLELISE:-} \
|
|
|
1cbe20 |
"${PKG_CFLAGS_BUILD:+CFLAGS=${PKG_CFLAGS_BUILD}}" \
|
|
|
1cbe20 |
"${PKG_CFLAGS_BUILD_EXTRA:+CFLAGS+=${PKG_CFLAGS_BUILD_EXTRA}}" \
|
|
|
1cbe20 |
"${PKG_CPPFLAGS_BUILD:+CPPFLAGS=${PKG_CPPFLAGS_BUILD}}" \
|
|
|
1cbe20 |
"${PKG_CPPFLAGS_BUILD_EXTRA:+CPPFLAGS+=${PKG_CPPFLAGS_BUILD_EXTRA}}" \
|
|
|
1cbe20 |
"${PKG_CXXFLAGS_BUILD:+CXXFLAGS=${PKG_CXXFLAGS_BUILD}}" \
|
|
|
1cbe20 |
"${PKG_CXXFLAGS_BUILD_EXTRA:+CXXFLAGS+=${PKG_CXXFLAGS_BUILD_EXTRA}}" \
|
|
|
1cbe20 |
"${PKG_LDFLAGS_BUILD:+LDFLAGS=${PKG_LDFLAGS_BUILD}}" \
|
|
|
1cbe20 |
"${PKG_LDFLAGS_BUILD_EXTRA:+LDFLAGS+=${PKG_LDFLAGS_BUILD_EXTRA}}" \
|
|
|
1cbe20 |
"${PKG_PKG_CONFIG:+PKG_CONFIG=${PKG_PKG_CONFIG}}" \
|
|
|
1cbe20 |
"${PKG_PKG_CONFIG_LIBDIR:+PKG_CONFIG_LIBDIR=${PKG_PKG_CONFIG_LIBDIR}}" \
|
|
|
1cbe20 |
${_pb_libtool:+"LIBTOOL=${_pb_libtool}"} \
|
|
|
1cbe20 |
${_pb_makeflags_verbosity} \
|
|
|
1cbe20 |
${_pb_subdir:+-C "${_pb_subdir}"};
|
|
|
1cbe20 |
_pb_rc="${?}";
|
|
|
1cbe20 |
fi;
|
|
|
e9fa07 |
|
|
|
e9fa07 |
if [ "${#_pb_libtool}" -gt 0 ]; then
|
|
|
e9fa07 |
unset MAKE;
|
|
|
e9fa07 |
fi;
|
|
|
e9fa07 |
|
|
|
e9fa07 |
if [ "${_pb_rc}" -ne 0 ]; then
|
|
|
e9fa07 |
break;
|
|
|
e9fa07 |
fi;
|
|
|
e9fa07 |
done;
|
|
|
e9fa07 |
|
|
|
e9fa07 |
return "${_pb_rc}";
|
|
|
e9fa07 |
};
|
|
|
e9fa07 |
|
|
|
64844b |
# vim:filetype=sh textwidth=0
|