Browse Source

Continuous output and failure

some attempt at using dpkg for termux package installs instead of
rebuilding from source
android-5
Stephen 8 years ago
committed by Fredrik Fornwall
parent
commit
06e5ec1f12
  1. 5
      .travis.yml
  2. 36
      Rakefile
  3. 15
      build-package.sh
  4. 2
      packages/git/build.sh
  5. 1
      packages/libuv/build.sh

5
.travis.yml

@ -1,6 +1,5 @@
language: ruby language: ruby
sudo: required sudo: required
services: cache: bundler
- docker services: docker
before_script: mkdir debs && chmod 777 debs before_script: mkdir debs && chmod 777 debs

36
Rakefile

@ -1,4 +1,5 @@
require 'rugged' require 'rugged'
require 'pty'
task default: %w[build] task default: %w[build]
@ -6,13 +7,32 @@ task :build do
repo = Rugged::Repository.new('.') repo = Rugged::Repository.new('.')
commit = repo.head.target commit = repo.head.target
parent = commit.parents.first parent = commit.parents.first
paths = commit.diff(parent).deltas.map { |d| d.new_file[:path] } pkgs = commit.diff(parent).deltas.map { |d| d.new_file[:path] }
paths = paths.map { |p| Pathname.new(p).each_filename.to_a } # Split paths into arrays
# looking for packages/[package]/... pkgs.map! { |p| Pathname.new(p).each_filename.to_a }
packages = paths.map { |p| p[1] if p.length > 2 and p[0] == "packages" } # looking for [disabled-]packages/(package_name)/...
packages = packages.flatten.uniq pkgs.select! { |p| p.length > 2 and p[0] =~ /(?<disabled->)packages/ }
packages.each do |package| # Get package_name
puts package pkgs.map! { |p| p[1] }
printf `./scripts/run-docker.sh ./build-package.sh #{package}` # Remove duplicate packages
pkgs.uniq!
pkgs.each do |pkg|
puts "Building #{pkg}"
begin
# Start blocking build loop
PTY.spawn("./scripts/run-docker.sh ./build-package.sh #{pkg}") do |stdout, stdin, pid|
begin
stdout.each { |line| print line }
rescue Errno::EIO
end
end
rescue PTY::ChildExited
puts "Process exited"
end
# Exit if PTY return a non-zero code
if $?.exitstatus != 0
STDERR.puts("Error building #{pkg}")
exit($?.exitstatus)
end
end end
end end

15
build-package.sh

@ -308,6 +308,21 @@ termux_step_start_build() {
for p in $TERMUX_ALL_DEPS; do for p in $TERMUX_ALL_DEPS; do
if [ "$p" != "$TERMUX_PKG_NAME" ]; then if [ "$p" != "$TERMUX_PKG_NAME" ]; then
echo "Building dependency $p if necessary..." echo "Building dependency $p if necessary..."
# TODO use apt and dpkg to install instead of building
# Add apt repository and key, update
# TODO move this install to Dockerfile
sudo apt-get update && sudo apt-get install -y software-properties-common
sudo add-apt-repository "deb [arch=all,$TERMUX_ARCH] http://termux.net stable main"
cat $TERMUX_SCRIPTDIR/packages/apt/trusted.gpg | sudo apt-key add -
sudo apt-get update && sudo dpkg --add-architecture $TERMUX_ARCH
sudo apt-get -d install ${p}:${TERMUX_ARCH}
# TODO delete debug info
echo "SGROAT DEBUG"
ls -lah /var/cache/apt/archives
echo "SGROAT DEBUG"
# TODO figure out what the root is?
sudo dpkg --root $TERMUX_PREFIX --configure -a
sudo dpkg --root $TERMUX_PREFIX -i /var/cache/apt/archives/${p}_*_${TERMUX_ARCH}.deb
./build-package.sh -a $TERMUX_ARCH -s "$p" ./build-package.sh -a $TERMUX_ARCH -s "$p"
fi fi
done done

2
packages/git/build.sh

@ -1,6 +1,6 @@
TERMUX_PKG_HOMEPAGE=https://git-scm.com/ TERMUX_PKG_HOMEPAGE=https://git-scm.com/
TERMUX_PKG_DESCRIPTION="Distributed version control system designed to handle everything from small to very large projects with speed and efficiency" TERMUX_PKG_DESCRIPTION="Distributed version control system designed to handle everything from small to very large projects with speed and efficiency"
# less is required as a pager for git log, and the busybox less does not handle used escape sequences. # less is required as a pager for git log, and the busybox less does not handle used escape sequences
TERMUX_PKG_DEPENDS="libcurl, less" TERMUX_PKG_DEPENDS="libcurl, less"
TERMUX_PKG_VERSION=2.13.3 TERMUX_PKG_VERSION=2.13.3
TERMUX_PKG_SRCURL=https://www.kernel.org/pub/software/scm/git/git-${TERMUX_PKG_VERSION}.tar.xz TERMUX_PKG_SRCURL=https://www.kernel.org/pub/software/scm/git/git-${TERMUX_PKG_VERSION}.tar.xz

1
packages/libuv/build.sh

@ -3,7 +3,6 @@ TERMUX_PKG_DESCRIPTION="Support library with a focus on asynchronous I/O"
TERMUX_PKG_VERSION=1.13.1 TERMUX_PKG_VERSION=1.13.1
TERMUX_PKG_SRCURL=http://dist.libuv.org/dist/v${TERMUX_PKG_VERSION}/libuv-v${TERMUX_PKG_VERSION}.tar.gz TERMUX_PKG_SRCURL=http://dist.libuv.org/dist/v${TERMUX_PKG_VERSION}/libuv-v${TERMUX_PKG_VERSION}.tar.gz
TERMUX_PKG_SHA256=824fe07476a9cab519d2d3e2be6d49f1faa1e7bb59224f0d81a7d6a307ce3937 TERMUX_PKG_SHA256=824fe07476a9cab519d2d3e2be6d49f1faa1e7bb59224f0d81a7d6a307ce3937
termux_step_pre_configure () { termux_step_pre_configure () {
export PLATFORM=android export PLATFORM=android
sh autogen.sh sh autogen.sh

Loading…
Cancel
Save