build-package.sh: better support for metapackages
This commit is contained in:
parent
e803bdd3ef
commit
5493481c5c
@ -1,4 +1,6 @@
|
|||||||
termux_step_configure() {
|
termux_step_configure() {
|
||||||
|
[ "$TERMUX_PKG_METAPACKAGE" = "true" ] && return
|
||||||
|
|
||||||
if [ "$TERMUX_PKG_FORCE_CMAKE" = "false" ] && [ -f "$TERMUX_PKG_SRCDIR/configure" ]; then
|
if [ "$TERMUX_PKG_FORCE_CMAKE" = "false" ] && [ -f "$TERMUX_PKG_SRCDIR/configure" ]; then
|
||||||
termux_step_configure_autotools
|
termux_step_configure_autotools
|
||||||
elif [ -f "$TERMUX_PKG_SRCDIR/CMakeLists.txt" ]; then
|
elif [ -f "$TERMUX_PKG_SRCDIR/CMakeLists.txt" ]; then
|
||||||
|
@ -8,7 +8,7 @@ termux_step_create_datatar() {
|
|||||||
termux_error_exit "Package contains hard links: $HARDLINKS"
|
termux_error_exit "Package contains hard links: $HARDLINKS"
|
||||||
fi
|
fi
|
||||||
|
|
||||||
if [ "${TERMUX_PKG_METAPACKAGE-false}" = "true" ]; then
|
if [ "$TERMUX_PKG_METAPACKAGE" = "true" ]; then
|
||||||
# Metapackage doesn't have data inside.
|
# Metapackage doesn't have data inside.
|
||||||
rm -rf data
|
rm -rf data
|
||||||
else
|
else
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
termux_step_extract_package() {
|
termux_step_extract_package() {
|
||||||
if [ -z "${TERMUX_PKG_SRCURL:=""}" ] || [ "${TERMUX_PKG_SKIP_SRC_EXTRACT-false}" = "true" ]; then
|
if [ -z "${TERMUX_PKG_SRCURL:=""}" ] || [ "${TERMUX_PKG_SKIP_SRC_EXTRACT-false}" = "true" ] || [ "$TERMUX_PKG_METAPACKAGE" = "true" ]; then
|
||||||
mkdir -p "$TERMUX_PKG_SRCDIR"
|
mkdir -p "$TERMUX_PKG_SRCDIR"
|
||||||
return
|
return
|
||||||
fi
|
fi
|
||||||
|
@ -1,5 +1,6 @@
|
|||||||
termux_step_handle_hostbuild() {
|
termux_step_handle_hostbuild() {
|
||||||
if [ "$TERMUX_PKG_HOSTBUILD" = "false" ]; then return; fi
|
[ "$TERMUX_PKG_METAPACKAGE" = "true" ] && return
|
||||||
|
[ "$TERMUX_PKG_HOSTBUILD" = "false" ] && return
|
||||||
|
|
||||||
cd "$TERMUX_PKG_SRCDIR"
|
cd "$TERMUX_PKG_SRCDIR"
|
||||||
for patch in $TERMUX_PKG_BUILDER_DIR/*.patch.beforehostbuild; do
|
for patch in $TERMUX_PKG_BUILDER_DIR/*.patch.beforehostbuild; do
|
||||||
|
@ -1,4 +1,6 @@
|
|||||||
termux_step_install_license() {
|
termux_step_install_license() {
|
||||||
|
[ "$TERMUX_PKG_METAPACKAGE" = "true" ] && return
|
||||||
|
|
||||||
mkdir -p "$TERMUX_PREFIX/share/doc/$TERMUX_PKG_NAME"
|
mkdir -p "$TERMUX_PREFIX/share/doc/$TERMUX_PKG_NAME"
|
||||||
|
|
||||||
if [ ! "${TERMUX_PKG_LICENSE_FILE}" = "" ]; then
|
if [ ! "${TERMUX_PKG_LICENSE_FILE}" = "" ]; then
|
||||||
|
@ -1,4 +1,6 @@
|
|||||||
termux_step_make() {
|
termux_step_make() {
|
||||||
|
[ "$TERMUX_PKG_METAPACKAGE" = "true" ] && return
|
||||||
|
|
||||||
local QUIET_BUILD=
|
local QUIET_BUILD=
|
||||||
if [ "$TERMUX_QUIET_BUILD" = true ]; then
|
if [ "$TERMUX_QUIET_BUILD" = true ]; then
|
||||||
QUIET_BUILD="-s"
|
QUIET_BUILD="-s"
|
||||||
|
@ -1,4 +1,6 @@
|
|||||||
termux_step_make_install() {
|
termux_step_make_install() {
|
||||||
|
[ "$TERMUX_PKG_METAPACKAGE" = "true" ] && return
|
||||||
|
|
||||||
if test -f build.ninja; then
|
if test -f build.ninja; then
|
||||||
ninja -w dupbuild=warn -j $TERMUX_MAKE_PROCESSES install
|
ninja -w dupbuild=warn -j $TERMUX_MAKE_PROCESSES install
|
||||||
elif ls ./*akefile &> /dev/null || [ -n "$TERMUX_PKG_EXTRA_MAKE_ARGS" ]; then
|
elif ls ./*akefile &> /dev/null || [ -n "$TERMUX_PKG_EXTRA_MAKE_ARGS" ]; then
|
||||||
|
@ -1,4 +1,6 @@
|
|||||||
termux_step_massage() {
|
termux_step_massage() {
|
||||||
|
[ "$TERMUX_PKG_METAPACKAGE" = "true" ] && return
|
||||||
|
|
||||||
cd "$TERMUX_PKG_MASSAGEDIR/$TERMUX_PREFIX"
|
cd "$TERMUX_PKG_MASSAGEDIR/$TERMUX_PREFIX"
|
||||||
|
|
||||||
# Remove lib/charset.alias which is installed by gettext-using packages:
|
# Remove lib/charset.alias which is installed by gettext-using packages:
|
||||||
|
@ -1,4 +1,6 @@
|
|||||||
termux_step_patch_package() {
|
termux_step_patch_package() {
|
||||||
|
[ "$TERMUX_PKG_METAPACKAGE" = "true" ] && return
|
||||||
|
|
||||||
cd "$TERMUX_PKG_SRCDIR"
|
cd "$TERMUX_PKG_SRCDIR"
|
||||||
local DEBUG_PATCHES=""
|
local DEBUG_PATCHES=""
|
||||||
if [ "$TERMUX_DEBUG" = "true" ]; then
|
if [ "$TERMUX_DEBUG" = "true" ]; then
|
||||||
|
@ -1,4 +1,6 @@
|
|||||||
termux_step_replace_guess_scripts() {
|
termux_step_replace_guess_scripts() {
|
||||||
|
[ "$TERMUX_PKG_METAPACKAGE" = "true" ] && return
|
||||||
|
|
||||||
cd "$TERMUX_PKG_SRCDIR"
|
cd "$TERMUX_PKG_SRCDIR"
|
||||||
find . -name config.sub -exec chmod u+w '{}' \; -exec cp "$TERMUX_SCRIPTDIR/scripts/config.sub" '{}' \;
|
find . -name config.sub -exec chmod u+w '{}' \; -exec cp "$TERMUX_SCRIPTDIR/scripts/config.sub" '{}' \;
|
||||||
find . -name config.guess -exec chmod u+w '{}' \; -exec cp "$TERMUX_SCRIPTDIR/scripts/config.guess" '{}' \;
|
find . -name config.guess -exec chmod u+w '{}' \; -exec cp "$TERMUX_SCRIPTDIR/scripts/config.guess" '{}' \;
|
||||||
|
@ -1,4 +1,6 @@
|
|||||||
termux_step_setup_toolchain() {
|
termux_step_setup_toolchain() {
|
||||||
|
[ "$TERMUX_PKG_METAPACKAGE" = "true" ] && return
|
||||||
|
|
||||||
export CFLAGS=""
|
export CFLAGS=""
|
||||||
export LDFLAGS="-L${TERMUX_PREFIX}/lib"
|
export LDFLAGS="-L${TERMUX_PREFIX}/lib"
|
||||||
|
|
||||||
|
@ -131,6 +131,7 @@ termux_step_setup_variables() {
|
|||||||
TERMUX_PKG_FORCE_CMAKE=false # if the package has autotools as well as cmake, then set this to prefer cmake
|
TERMUX_PKG_FORCE_CMAKE=false # if the package has autotools as well as cmake, then set this to prefer cmake
|
||||||
TERMUX_CMAKE_BUILD=Ninja # Which cmake generator to use
|
TERMUX_CMAKE_BUILD=Ninja # Which cmake generator to use
|
||||||
TERMUX_PKG_HAS_DEBUG=true # set to false if debug build doesn't exist or doesn't work, for example for python based packages
|
TERMUX_PKG_HAS_DEBUG=true # set to false if debug build doesn't exist or doesn't work, for example for python based packages
|
||||||
|
TERMUX_PKG_METAPACKAGE=false
|
||||||
|
|
||||||
unset CFLAGS CPPFLAGS LDFLAGS CXXFLAGS
|
unset CFLAGS CPPFLAGS LDFLAGS CXXFLAGS
|
||||||
}
|
}
|
||||||
|
@ -2,6 +2,12 @@ termux_step_start_build() {
|
|||||||
# shellcheck source=/dev/null
|
# shellcheck source=/dev/null
|
||||||
source "$TERMUX_PKG_BUILDER_SCRIPT"
|
source "$TERMUX_PKG_BUILDER_SCRIPT"
|
||||||
|
|
||||||
|
if [ "$TERMUX_PKG_METAPACKAGE" = "true" ]; then
|
||||||
|
# Metapackage has no sources and therefore platform-independent.
|
||||||
|
TERMUX_PKG_SKIP_SRC_EXTRACT=true
|
||||||
|
TERMUX_PKG_PLATFORM_INDEPENDENT=true
|
||||||
|
fi
|
||||||
|
|
||||||
TERMUX_STANDALONE_TOOLCHAIN="$TERMUX_COMMON_CACHEDIR/android-r${TERMUX_NDK_VERSION}-api-${TERMUX_PKG_API_LEVEL}"
|
TERMUX_STANDALONE_TOOLCHAIN="$TERMUX_COMMON_CACHEDIR/android-r${TERMUX_NDK_VERSION}-api-${TERMUX_PKG_API_LEVEL}"
|
||||||
# Bump the below version if a change is made in toolchain setup to ensure
|
# Bump the below version if a change is made in toolchain setup to ensure
|
||||||
# that everyone gets an updated toolchain:
|
# that everyone gets an updated toolchain:
|
||||||
@ -41,7 +47,7 @@ termux_step_start_build() {
|
|||||||
fi
|
fi
|
||||||
fi
|
fi
|
||||||
|
|
||||||
if [ "$TERMUX_SKIP_DEPCHECK" = false ] && [ "$TERMUX_INSTALL_DEPS" = true ]; then
|
if [ "$TERMUX_SKIP_DEPCHECK" = false ] && [ "$TERMUX_INSTALL_DEPS" = true ] && [ "$TERMUX_PKG_METAPACKAGE" = "false" ]; then
|
||||||
# Download repo files
|
# Download repo files
|
||||||
termux_get_repo_files
|
termux_get_repo_files
|
||||||
|
|
||||||
@ -87,7 +93,7 @@ termux_step_start_build() {
|
|||||||
mkdir -p $TERMUX_BUILT_PACKAGES_DIRECTORY
|
mkdir -p $TERMUX_BUILT_PACKAGES_DIRECTORY
|
||||||
echo "$DEP_VERSION" > "$TERMUX_BUILT_PACKAGES_DIRECTORY/$PKG"
|
echo "$DEP_VERSION" > "$TERMUX_BUILT_PACKAGES_DIRECTORY/$PKG"
|
||||||
done<<<$(./scripts/buildorder.py -i "$TERMUX_PKG_BUILDER_DIR" $TERMUX_PACKAGES_DIRECTORIES || echo "ERROR")
|
done<<<$(./scripts/buildorder.py -i "$TERMUX_PKG_BUILDER_DIR" $TERMUX_PACKAGES_DIRECTORIES || echo "ERROR")
|
||||||
elif [ "$TERMUX_SKIP_DEPCHECK" = false ] && [ "$TERMUX_INSTALL_DEPS" = false ]; then
|
elif [ "$TERMUX_SKIP_DEPCHECK" = false ] && [ "$TERMUX_INSTALL_DEPS" = false ] && [ "$TERMUX_PKG_METAPACKAGE" = "false" ]; then
|
||||||
# Build dependencies
|
# Build dependencies
|
||||||
while read PKG PKG_DIR; do
|
while read PKG PKG_DIR; do
|
||||||
if [ -z $PKG ]; then
|
if [ -z $PKG ]; then
|
||||||
|
Loading…
Reference in New Issue
Block a user