forked from Mirror/pmbootstrap
Use a deterministic mirror URL instead of CDN for aportgen. Otherwise we may generate a pmaport that wraps an apk from Alpine (e.g. musl-armv7) locally with one up-to-date mirror given by the CDN. But then the build will fail if CDN picks an outdated mirror for CI or BPO.
99 lines
3.9 KiB
Python
99 lines
3.9 KiB
Python
# Copyright 2020 Oliver Smith
|
|
# SPDX-License-Identifier: GPL-3.0-or-later
|
|
import pmb.aportgen.core
|
|
import pmb.build
|
|
import pmb.chroot.apk
|
|
import pmb.chroot.apk_static
|
|
import pmb.helpers.run
|
|
import pmb.parse.apkindex
|
|
|
|
|
|
def generate(args, pkgname):
|
|
# Parse musl version from APKINDEX
|
|
package_data = pmb.parse.apkindex.package(args, "musl")
|
|
version = package_data["version"]
|
|
pkgver = version.split("-r")[0]
|
|
pkgrel = version.split("-r")[1]
|
|
|
|
# Architectures to build this package for
|
|
arch = pkgname.split("-")[1]
|
|
arches = list(pmb.config.build_device_architectures)
|
|
arches.remove(arch)
|
|
|
|
# Prepare aportgen tempdir inside and outside of chroot
|
|
tempdir = "/tmp/aportgen"
|
|
pmb.chroot.root(args, ["rm", "-rf", tempdir])
|
|
pmb.helpers.run.user(args, ["mkdir", "-p", f"{args.work}/aportgen",
|
|
f"{args.work}/chroot_native/{tempdir}"])
|
|
|
|
# Write the APKBUILD
|
|
channel_cfg = pmb.config.pmaports.read_config_channel(args)
|
|
mirrordir = channel_cfg["mirrordir_alpine"]
|
|
apkbuild_path = f"{args.work}/chroot_native/{tempdir}/APKBUILD"
|
|
with open(apkbuild_path, "w", encoding="utf-8") as handle:
|
|
apkbuild = f"""\
|
|
# Automatically generated aport, do not edit!
|
|
# Generator: pmbootstrap aportgen {pkgname}
|
|
|
|
# Stub for apkbuild-lint
|
|
if [ -z "$(type -t arch_to_hostspec)" ]; then
|
|
arch_to_hostspec() {{ :; }}
|
|
fi
|
|
|
|
pkgname={pkgname}
|
|
pkgver={pkgver}
|
|
pkgrel={pkgrel}
|
|
arch="{" ".join(arches)}"
|
|
subpackages="musl-dev-{arch}:package_dev"
|
|
|
|
_arch="{arch}"
|
|
_mirror="{pmb.config.aportgen_mirror_alpine}"
|
|
|
|
url="https://musl-libc.org"
|
|
license="MIT"
|
|
options="!check !strip"
|
|
pkgdesc="the musl library (lib c) implementation for $_arch"
|
|
|
|
_target="$(arch_to_hostspec $_arch)"
|
|
|
|
source="
|
|
musl-$pkgver-r$pkgrel-$_arch-{mirrordir}.apk::$_mirror/{mirrordir}/main/$_arch/musl-$pkgver-r$pkgrel.apk
|
|
musl-dev-$pkgver-r$pkgrel-$_arch-{mirrordir}.apk::$_mirror/{mirrordir}/main/$_arch/musl-dev-$pkgver-r$pkgrel.apk
|
|
"
|
|
|
|
package() {{
|
|
mkdir -p "$pkgdir/usr/$_target"
|
|
cd "$pkgdir/usr/$_target"
|
|
# Use 'busybox tar' to avoid 'tar: Child returned status 141'
|
|
# on some machines (builds.sr.ht, gitlab-ci). See pmaports#26.
|
|
busybox tar -xf $srcdir/musl-$pkgver-r$pkgrel-$_arch-{mirrordir}.apk
|
|
rm .PKGINFO .SIGN.*
|
|
}}
|
|
package_dev() {{
|
|
mkdir -p "$subpkgdir/usr/$_target"
|
|
cd "$subpkgdir/usr/$_target"
|
|
# Use 'busybox tar' to avoid 'tar: Child returned status 141'
|
|
# on some machines (builds.sr.ht, gitlab-ci). See pmaports#26.
|
|
busybox tar -xf $srcdir/musl-dev-$pkgver-r$pkgrel-$_arch-{mirrordir}.apk
|
|
rm .PKGINFO .SIGN.*
|
|
|
|
# symlink everything from /usr/$_target/usr/* to /usr/$_target/*
|
|
# so the cross-compiler gcc does not fail to build.
|
|
for _dir in include lib; do
|
|
mkdir -p "$subpkgdir/usr/$_target/$_dir"
|
|
cd "$subpkgdir/usr/$_target/usr/$_dir"
|
|
for i in *; do
|
|
cd "$subpkgdir/usr/$_target/$_dir"
|
|
ln -s /usr/$_target/usr/$_dir/$i $i
|
|
done
|
|
done
|
|
}}
|
|
"""
|
|
for line in apkbuild.split("\n"):
|
|
handle.write(line[12:].replace(" " * 4, "\t") + "\n")
|
|
|
|
# Generate checksums
|
|
pmb.build.init(args)
|
|
pmb.chroot.root(args, ["chown", "-R", "pmos:pmos", tempdir])
|
|
pmb.chroot.user(args, ["abuild", "checksum"], working_dir=tempdir)
|
|
pmb.helpers.run.user(args, ["cp", apkbuild_path, f"{args.work}/aportgen"])
|