Browse Source

updates

android-5
Henrik Grimler 6 years ago
parent
commit
bc7037964e
  1. 121
      build-package.sh

121
build-package.sh

@ -254,20 +254,20 @@ termux_step_handle_arguments() {
echo " -d Build with debug symbols."
echo " -D Build a disabled package in disabled-packages/."
echo " -f Force build even if package has already been built."
echo " -i Install dependencies."
echo " -i Build dependencies."
echo " -q Quiet build."
echo " -s Skip dependency check."
echo " -o Specify deb directory. Default: debs/."
exit 1
}
while getopts :a:hdDfqso: option; do
while getopts :a:hdDfiqso: option; do
case "$option" in
a) TERMUX_ARCH="$OPTARG";;
h) _show_usage;;
d) export TERMUX_DEBUG=true;;
D) local TERMUX_IS_DISABLED=true;;
f) TERMUX_FORCE_BUILD=true;;
i) export TERMUX_INSTALL_DEPS=true;;
i) export TERMUX_BUILD_DEPS=true;;
q) export TERMUX_QUIET_BUILD=true;;
s) export TERMUX_SKIP_DEPCHECK=true;;
o) TERMUX_DEBDIR="$(realpath -m $OPTARG)";;
@ -323,6 +323,7 @@ termux_step_setup_variables() {
: "${TERMUX_DEBUG:=""}"
: "${TERMUX_PKG_API_LEVEL:="21"}"
: "${TERMUX_DEBDIR:="${TERMUX_SCRIPTDIR}/debs"}"
: "${TERMUX_REPO_URL:="https://termux.net/dists/stable/main"}"
if [ "x86_64" = "$TERMUX_ARCH" ] || [ "aarch64" = "$TERMUX_ARCH" ]; then
TERMUX_ARCH_BITS=64
@ -403,7 +404,7 @@ termux_step_handle_buildarch() {
local TERMUX_PREVIOUS_ARCH
TERMUX_PREVIOUS_ARCH=$(cat $TERMUX_ARCH_FILE)
if [ "$TERMUX_PREVIOUS_ARCH" != "$TERMUX_ARCH" ]; then
local TERMUX_DATA_BACKUPDIRS=$TERMUX_TOPDIR/_databackups
local TERMUX_DATA_BACKUPDIRS=$TERMUX_TOPDIR/_databackups
mkdir -p "$TERMUX_DATA_BACKUPDIRS"
local TERMUX_DATA_PREVIOUS_BACKUPDIR=$TERMUX_DATA_BACKUPDIRS/$TERMUX_PREVIOUS_ARCH
local TERMUX_DATA_CURRENT_BACKUPDIR=$TERMUX_DATA_BACKUPDIRS/$TERMUX_ARCH
@ -440,10 +441,11 @@ termux_step_start_build() {
exit 0
fi
if [ ! -z ${TERMUX_INSTALL_DEPS+x} ]; then
if [ ! ${TERMUX_BUILD_DEPS:=false} = true ]; then
# Ensure folders present (but not $TERMUX_PKG_SRCDIR, it will be created in build)
mkdir -p "$TERMUX_COMMON_CACHEDIR" \
"$TERMUX_DEBDIR" \
"${TERMUX_COMMON_CACHEDIR}-${TERMUX_ARCH}" \
"$TERMUX_DEBDIR" \
"$TERMUX_PKG_BUILDDIR" \
"$TERMUX_PKG_PACKAGEDIR" \
"$TERMUX_PKG_TMPDIR" \
@ -452,74 +454,33 @@ termux_step_start_build() {
$TERMUX_PREFIX/{bin,etc,lib,libexec,share,tmp,include}
# Setup bootstrap
termux_download https://termux.net/bootstrap/bootstrap-${TERMUX_ARCH}.zip \
${TERMUX_COMMON_CACHEDIR}/bootstrap-${TERMUX_ARCH}.zip
unzip ${TERMUX_COMMON_CACHEDIR}/bootstrap-${TERMUX_ARCH}.zip -d $TERMUX_PREFIX
# TODO move this install to Dockerfile
sudo apt-get update && sudo apt-get -y dist-upgrade && sudo apt-get install -y libcap2-bin gawk tree strace devscripts
# set capabilities on dpkg
# Some packages built by uid 1001 (builder is 1000)
# Need capabilities for dpkg to set non-builder uid
sudo /sbin/setcap cap_chown,cap_fowner,cap_dac_override+eip /usr/bin/dpkg
sudo /sbin/setcap cap_chown,cap_fowner,cap_dac_override+eip /usr/bin/apt-get
# install packages that include subpackages
sudo sed -i -e 's/DPkg::Pre-Install-Pkgs/\/\/ DPkg::Pre-Install-Pkgs/' /etc/apt/apt.conf.d/*
sudo sed -i -e 's/DPkg::Post-Invoke/\/\/ DPkg::Post-Invoke/' /etc/apt/apt.conf.d/*
sudo sed -i -e 's/APT::Update::Post-Invoke/\/\/ APT::Update::Post-Invoke/' /etc/apt/apt.conf.d/*
TERMUX_DPKG=" \
--force-architecture \
--force-not-root \
--force-configure-any \
--force-confdef \
--force-confold \
--force-depends \
--admindir=${TERMUX_PREFIX}/var/lib/dpkg"
export TERMUX_APT=" \
-o APT::Get::Assume-Yes=true \
-o APT::Get::ReInstall=true
-o APT::Get::Install-Recommends=false \
-o APT::Get::Install-Suggests=false \
-o APT::Architecture=${TERMUX_ARCH} \
-o Dir::Etc=${TERMUX_PREFIX}/etc/apt/ \
-o Dir::State=${TERMUX_PREFIX}/var/lib/apt \
-o Dir::State::status=${TERMUX_PREFIX}/var/lib/dpkg/status \
-o Dir::Cache=${TERMUX_PREFIX}/var/cache/apt \
-o Dir::Log=${TERMUX_PREFIX}/var/log/apt"
for arg in ${TERMUX_DPKG}; do
TERMUX_APT+=" -o DPkg::Options::=${arg}"
done
export DEBCONF_FRONTEND=noninteractive
apt-get $TERMUX_APT clean && apt-get $TERMUX_APT update && apt-get $TERMUX_APT upgrade
# libandroid-support-dev is build-essential
apt-get $TERMUX_APT install libandroid-support-dev:any
sudo chown -R builder:builder /data
array=( TERMUX_PKG_DEPENDS TERMUX_PKG_BUILD_DEPENDS )
for i in "${array[@]}"; do
while IFS=',' read -ra PKG; do
for p in "${PKG[@]}"; do
p="$(echo -e "${p}" | tr -d '[:space:]')"
# Install packages and dev packages and escape + with \+ to avoid apt regex
apt-get $TERMUX_APT install "^${p//+/\\+}(-dev)?$":any
sudo chown -R builder:builder /data
done
done <<< "${!i}"
done
for subpkg in $TERMUX_PKG_BUILDER_DIR/*.subpackage.sh; do
test ! -f "$subpkg" && continue
local TERMUX_SUBPKG_DEPENDS=""
source $subpkg
while IFS=',' read -ra PKG; do
for p in "${PKG[@]}"; do
p="$(echo -e "${p}" | tr -d '[:space:]')"
# Install packages and dev packages and escape + with \+ to avoid apt regex
apt-get $TERMUX_APT install "^${p//+/\\+}(-dev)?$":any
sudo chown -R builder:builder /data
done
done <<< $TERMUX_SUBPKG_DEPENDS
${TERMUX_COMMON_CACHEDIR}/bootstrap-${TERMUX_ARCH}.zip \
9f43bfdd23fbc6ae02f1f5a44b8e064374db8291ffe32658e2724d3f3f419981
unzip -qo ${TERMUX_COMMON_CACHEDIR}/bootstrap-${TERMUX_ARCH}.zip -d $TERMUX_PREFIX
(
cd $TERMUX_PREFIX
while read line; do
ln -sf ${line/←/ }
done<SYMLINKS.txt
rm SYMLINKS.txt
)
fi
if [ ! ${TERMUX_BUILD_DEPS:=false} = true ] && [ ! ${TERMUX_SKIP_DEPCHECK:=false} = true ]; then
# download dependencies
local p TERMUX_ALL_DEPS
TERMUX_ALL_DEPS=$(./scripts/buildorder.py "$TERMUX_PKG_BUILDER_DIR")
for p in $TERMUX_ALL_DEPS; do
echo "Downloading dependency $(basename $p) if necessary..."
# termux_get_deb $TERMUX_ARCH "$p"
local p_ver=$(termux_extract_version "$p")
echo "hej"
echo "$p_ver"
echo "håå"
done
fi
if [ -z "${TERMUX_SKIP_DEPCHECK:=""}" ] && [ -z ${TERMUX_INSTALL_DEPS+x} ]; then
if [ -z "${TERMUX_SKIP_DEPCHECK:=""}" ] && [ ${TERMUX_BUILD_DEPS:=false} = true ]; then
echo "WE MADE IT"
local p TERMUX_ALL_DEPS
TERMUX_ALL_DEPS=$(./scripts/buildorder.py "$TERMUX_PKG_BUILDER_DIR")
for p in $TERMUX_ALL_DEPS; do
@ -527,6 +488,18 @@ termux_step_start_build() {
# Built dependencies are put in the default TERMUX_DEBDIR instead of the specified one
./build-package.sh -a $TERMUX_ARCH -s "$p"
done
# elif [ ! -z "${TERMUX_SKIP_DEPCHECK:=""}" ]; then
# # download dependencies
# local p TERMUX_ALL_DEPS
# TERMUX_ALL_DEPS=$(./scripts/buildorder.py "$TERMUX_PKG_BUILDER_DIR")
# for p in $TERMUX_ALL_DEPS; do
# echo "Downloading dependency $(basename $p) if necessary..."
# # termux_get_deb $TERMUX_ARCH "$p"
# local p_ver=$(termux_extract_version "$p")
# echo "hej"
# echo "$p_ver"
# echo "håå"
# done
fi
TERMUX_PKG_FULLVERSION=$TERMUX_PKG_VERSION
@ -1384,13 +1357,13 @@ termux_step_create_debfile() {
}
termux_step_reverse_depends() {
if [ ! -z ${TERMUX_INSTALL_DEPS+x} ]; then
if [ ! ${TERMUX_BUILD_DEPS:=false} = true ]; then
# TODO build reverse depends with packages
apt-cache $TERMUX_APT rdepends $TERMUX_PKG_NAME
### apt-cache $TERMUX_APT rdepends $TERMUX_PKG_NAME
# TODO compare package with existing
echo "COMPARING PACKAGES"
apt $TERMUX_APT download $TERMUX_PKG_NAME
### apt $TERMUX_APT download $TERMUX_PKG_NAME
debdiff ${TERMUX_PKG_NAME}*.deb ${TERMUX_PKG_DEBFILE}
echo "DONE COMPARE PACKAGES"
fi

Loading…
Cancel
Save