Browse Source
mv code to create subpackages to new file and add support for TERMUX_SUBPKG_BREAKSandroid-5
Henrik Grimler
6 years ago
committed by
GitHub
4 changed files with 90 additions and 81 deletions
@ -0,0 +1,84 @@ |
|||
termux_create_subpackages() { |
|||
# Sub packages: |
|||
if [ -d include ] && [ -z "${TERMUX_PKG_NO_DEVELSPLIT}" ]; then |
|||
# Add virtual -dev sub package if there are include files: |
|||
local _DEVEL_SUBPACKAGE_FILE=$TERMUX_PKG_TMPDIR/${TERMUX_PKG_NAME}-dev.subpackage.sh |
|||
echo TERMUX_SUBPKG_INCLUDE=\"include share/vala share/man/man3 lib/pkgconfig share/aclocal lib/cmake $TERMUX_PKG_INCLUDE_IN_DEVPACKAGE\" > "$_DEVEL_SUBPACKAGE_FILE" |
|||
echo "TERMUX_SUBPKG_DESCRIPTION=\"Development files for ${TERMUX_PKG_NAME}\"" >> "$_DEVEL_SUBPACKAGE_FILE" |
|||
if [ -n "$TERMUX_PKG_DEVPACKAGE_DEPENDS" ]; then |
|||
echo "TERMUX_SUBPKG_DEPENDS=\"$TERMUX_PKG_NAME,$TERMUX_PKG_DEVPACKAGE_DEPENDS\"" >> "$_DEVEL_SUBPACKAGE_FILE" |
|||
else |
|||
echo "TERMUX_SUBPKG_DEPENDS=\"$TERMUX_PKG_NAME\"" >> "$_DEVEL_SUBPACKAGE_FILE" |
|||
fi |
|||
fi |
|||
# Now build all sub packages |
|||
rm -Rf "$TERMUX_TOPDIR/$TERMUX_PKG_NAME/subpackages" |
|||
for subpackage in $TERMUX_PKG_BUILDER_DIR/*.subpackage.sh $TERMUX_PKG_TMPDIR/*subpackage.sh; do |
|||
test ! -f "$subpackage" && continue |
|||
local SUB_PKG_NAME |
|||
SUB_PKG_NAME=$(basename "$subpackage" .subpackage.sh) |
|||
# Default value is same as main package, but sub package may override: |
|||
local TERMUX_SUBPKG_PLATFORM_INDEPENDENT=$TERMUX_PKG_PLATFORM_INDEPENDENT |
|||
local SUB_PKG_DIR=$TERMUX_TOPDIR/$TERMUX_PKG_NAME/subpackages/$SUB_PKG_NAME |
|||
local TERMUX_SUBPKG_BREAKS="" |
|||
local TERMUX_SUBPKG_DEPENDS="" |
|||
local TERMUX_SUBPKG_CONFLICTS="" |
|||
local TERMUX_SUBPKG_REPLACES="" |
|||
local TERMUX_SUBPKG_CONFFILES="" |
|||
local SUB_PKG_MASSAGE_DIR=$SUB_PKG_DIR/massage/$TERMUX_PREFIX |
|||
local SUB_PKG_PACKAGE_DIR=$SUB_PKG_DIR/package |
|||
mkdir -p "$SUB_PKG_MASSAGE_DIR" "$SUB_PKG_PACKAGE_DIR" |
|||
|
|||
# shellcheck source=/dev/null |
|||
source "$subpackage" |
|||
|
|||
for includeset in $TERMUX_SUBPKG_INCLUDE; do |
|||
local _INCLUDE_DIRSET |
|||
_INCLUDE_DIRSET=$(dirname "$includeset") |
|||
test "$_INCLUDE_DIRSET" = "." && _INCLUDE_DIRSET="" |
|||
if [ -e "$includeset" ] || [ -L "$includeset" ]; then |
|||
# Add the -L clause to handle relative symbolic links: |
|||
mkdir -p "$SUB_PKG_MASSAGE_DIR/$_INCLUDE_DIRSET" |
|||
mv "$includeset" "$SUB_PKG_MASSAGE_DIR/$_INCLUDE_DIRSET" |
|||
fi |
|||
done |
|||
|
|||
local SUB_PKG_ARCH=$TERMUX_ARCH |
|||
test -n "$TERMUX_SUBPKG_PLATFORM_INDEPENDENT" && SUB_PKG_ARCH=all |
|||
|
|||
cd "$SUB_PKG_DIR/massage" |
|||
local SUB_PKG_INSTALLSIZE |
|||
SUB_PKG_INSTALLSIZE=$(du -sk . | cut -f 1) |
|||
tar -cJf "$SUB_PKG_PACKAGE_DIR/data.tar.xz" . |
|||
|
|||
mkdir -p DEBIAN |
|||
cd DEBIAN |
|||
cat > control <<-HERE |
|||
Package: $SUB_PKG_NAME |
|||
Architecture: ${SUB_PKG_ARCH} |
|||
Installed-Size: ${SUB_PKG_INSTALLSIZE} |
|||
Maintainer: $TERMUX_PKG_MAINTAINER |
|||
Version: $TERMUX_PKG_FULLVERSION |
|||
Homepage: $TERMUX_PKG_HOMEPAGE |
|||
HERE |
|||
test ! -z "$TERMUX_SUBPKG_BREAKS" && echo "Breaks: $TERMUX_SUBPKG_BREAKS" >> control |
|||
test ! -z "$TERMUX_SUBPKG_DEPENDS" && echo "Depends: $TERMUX_SUBPKG_DEPENDS" >> control |
|||
test ! -z "$TERMUX_SUBPKG_CONFLICTS" && echo "Conflicts: $TERMUX_SUBPKG_CONFLICTS" >> control |
|||
test ! -z "$TERMUX_SUBPKG_REPLACES" && echo "Replaces: $TERMUX_SUBPKG_REPLACES" >> control |
|||
echo "Description: $TERMUX_SUBPKG_DESCRIPTION" >> control |
|||
tar -czf "$SUB_PKG_PACKAGE_DIR/control.tar.gz" . |
|||
|
|||
for f in $TERMUX_SUBPKG_CONFFILES; do echo "$TERMUX_PREFIX/$f" >> conffiles; done |
|||
|
|||
# Create the actual .deb file: |
|||
TERMUX_SUBPKG_DEBFILE=$TERMUX_DEBDIR/${SUB_PKG_NAME}${DEBUG}_${TERMUX_PKG_FULLVERSION}_${SUB_PKG_ARCH}.deb |
|||
test ! -f "$TERMUX_COMMON_CACHEDIR/debian-binary" && echo "2.0" > "$TERMUX_COMMON_CACHEDIR/debian-binary" |
|||
ar cr "$TERMUX_SUBPKG_DEBFILE" \ |
|||
"$TERMUX_COMMON_CACHEDIR/debian-binary" \ |
|||
"$SUB_PKG_PACKAGE_DIR/control.tar.gz" \ |
|||
"$SUB_PKG_PACKAGE_DIR/data.tar.xz" |
|||
|
|||
# Go back to main package: |
|||
cd "$TERMUX_PKG_MASSAGEDIR/$TERMUX_PREFIX" |
|||
done |
|||
} |
Loading…
Reference in new issue