mirror of
				https://gitlab.archlinux.org/archlinux/devtools.git
				synced 2025-11-04 09:44:42 +01:00 
			
		
		
		
	Compare commits
	
		
			10 Commits
		
	
	
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
| 
						 | 
					aff81d34fd | ||
| 
						 | 
					5b1123e11f | ||
| 
						 | 
					a0f79fcce0 | ||
| 
						 | 
					94b0413e13 | ||
| 
						 | 
					e963b6da9e | ||
| 
						 | 
					b2cbb8628e | ||
| 
						 | 
					6d273f79c3 | ||
| 
						 | 
					51842a1676 | ||
| 
						 | 
					53fe5c67a1 | ||
| 
						 | 
					21d9984acc | 
							
								
								
									
										2
									
								
								Makefile
									
									
									
									
									
								
							
							
						
						
									
										2
									
								
								Makefile
									
									
									
									
									
								
							@@ -1,4 +1,4 @@
 | 
			
		||||
V=20200213
 | 
			
		||||
V=20200407
 | 
			
		||||
 | 
			
		||||
PREFIX = /usr/local
 | 
			
		||||
MANDIR = $(PREFIX)/share/man
 | 
			
		||||
 
 | 
			
		||||
@@ -69,7 +69,9 @@ host_mirrors=($($pacconf_cmd --repo extra Server 2> /dev/null | sed -r 's#(.*/)e
 | 
			
		||||
for host_mirror in "${host_mirrors[@]}"; do
 | 
			
		||||
	if [[ $host_mirror == *file://* ]]; then
 | 
			
		||||
		host_mirror=$(echo "$host_mirror" | sed -r 's#file://(/.*)/\$repo/os/\$arch#\1#g')
 | 
			
		||||
		in_array "$host_mirror" "${cache_dirs[@]}" || cache_dirs+=("$host_mirror")
 | 
			
		||||
		for m in "$host_mirror"/pool/*/; do
 | 
			
		||||
			in_array "$m" "${cache_dirs[@]}" || cache_dirs+=("$m")
 | 
			
		||||
		done
 | 
			
		||||
	fi
 | 
			
		||||
done
 | 
			
		||||
 | 
			
		||||
 
 | 
			
		||||
@@ -95,8 +95,10 @@ for _pkgname in "${pkgname[@]}"; do
 | 
			
		||||
 | 
			
		||||
	if (( $# )); then
 | 
			
		||||
		case $1 in
 | 
			
		||||
			*://*)
 | 
			
		||||
				pkgurl=$1 ;;
 | 
			
		||||
			/*|*/*)
 | 
			
		||||
				pkgurl=file://$(readlink -m "$1") ;;
 | 
			
		||||
				pkgurl=$(readlink -m "$1") ;;
 | 
			
		||||
			*.pkg.tar*)
 | 
			
		||||
				pkgurl=$1 ;;
 | 
			
		||||
			'')
 | 
			
		||||
 
 | 
			
		||||
@@ -7,12 +7,12 @@ makerepropkg - Rebuild a package to see if it is reproducible
 | 
			
		||||
 | 
			
		||||
Synopsis
 | 
			
		||||
--------
 | 
			
		||||
makerepropkg [OPTIONS] <package_file>
 | 
			
		||||
makerepropkg [OPTIONS] <package_file>...
 | 
			
		||||
 | 
			
		||||
Description
 | 
			
		||||
-----------
 | 
			
		||||
 | 
			
		||||
Given the path to a built pacman package, attempt to rebuild it using the
 | 
			
		||||
Given the path to a built pacman package(s), attempt to rebuild it using the
 | 
			
		||||
PKGBUILD in the current directory. The package will be built in an environment
 | 
			
		||||
as closely matching the environment of the initial package as possible, by
 | 
			
		||||
building up a chroot to match the information exposed in the package's
 | 
			
		||||
@@ -20,12 +20,19 @@ linkman:BUILDINFO[5] manifest. On success, the resulting package will be
 | 
			
		||||
compared to the input package, and makerepropkg will report whether the
 | 
			
		||||
artifacts are identical.
 | 
			
		||||
 | 
			
		||||
When given multiple packages, additional package files are assumed to be split
 | 
			
		||||
packages and will be treated as additional artifacts to compare during the
 | 
			
		||||
verification step.
 | 
			
		||||
 | 
			
		||||
This implements a verifier for pacman/libalpm packages in accordance with the
 | 
			
		||||
link:https://reproducible-builds.org/[Reproducible Builds] project.
 | 
			
		||||
 | 
			
		||||
Options
 | 
			
		||||
-------
 | 
			
		||||
 | 
			
		||||
*-d*::
 | 
			
		||||
	If packages are not reproducible, compare them using diffoscope.
 | 
			
		||||
 | 
			
		||||
*-c*::
 | 
			
		||||
	Set the pacman cache directory.
 | 
			
		||||
 | 
			
		||||
 
 | 
			
		||||
@@ -366,11 +366,7 @@ if arch-nspawn "$copydir" \
 | 
			
		||||
	"${bindmounts_ro[@]}" "${bindmounts_rw[@]}" \
 | 
			
		||||
	/chrootbuild "${makepkg_args[@]}"
 | 
			
		||||
then
 | 
			
		||||
	pkgnames=()
 | 
			
		||||
	for pkgfile in "$copydir"/pkgdest/*; do
 | 
			
		||||
		pkgfile=${pkgfile##*/};
 | 
			
		||||
		pkgnames+=("${pkgfile%-*-*-*}");
 | 
			
		||||
	done
 | 
			
		||||
	mapfile -t pkgnames < <(sudo -u "$makepkg_user" bash -c 'source PKGBUILD; printf "%s\n" "${pkgname[@]}"')
 | 
			
		||||
	move_products
 | 
			
		||||
else
 | 
			
		||||
	(( ret += 1 ))
 | 
			
		||||
@@ -388,29 +384,29 @@ else
 | 
			
		||||
	if (( run_checkpkg )); then
 | 
			
		||||
		msg "Running checkpkg"
 | 
			
		||||
 | 
			
		||||
		# sync off-site databases for up-to-date queries
 | 
			
		||||
		trap 'rm -rf $dbpath; cleanup' EXIT INT TERM QUIT
 | 
			
		||||
		dbpath=$(mktemp -d --tmpdir makechrootpkg-database.XXXXXXXXXX)
 | 
			
		||||
		mkdir -p "$dbpath"
 | 
			
		||||
		pacman -Sy --dbpath "$dbpath" --logfile /dev/null
 | 
			
		||||
		mapfile -t remotepkgs < <(pacman --config "$copydir"/etc/pacman.conf \
 | 
			
		||||
			--dbpath "$copydir"/var/lib/pacman \
 | 
			
		||||
			-Sddp "${pkgnames[@]}")
 | 
			
		||||
 | 
			
		||||
		# query current package locations
 | 
			
		||||
		remotepkgs=($(pacman -Sddp --dbpath "$dbpath" --logfile /dev/null "${pkgnames[@]}"))
 | 
			
		||||
		if (( $? )); then
 | 
			
		||||
		if ! wait $!; then
 | 
			
		||||
			warning "Skipped checkpkg due to missing repo packages"
 | 
			
		||||
			exit 0
 | 
			
		||||
		fi
 | 
			
		||||
 | 
			
		||||
		# download package files if any non-local location exists
 | 
			
		||||
		for remotepkg in "${remotepkgs[@]}"; do
 | 
			
		||||
			[[ $remotepkg == file://* ]] && continue
 | 
			
		||||
			msg2 "Downloading current versions"
 | 
			
		||||
			pacman --noconfirm -Swdd --dbpath "$dbpath" --logfile /dev/null "${pkgnames[@]}"
 | 
			
		||||
			break
 | 
			
		||||
			if [[ $remotepkg != file://* ]]; then
 | 
			
		||||
				msg2 "Downloading current versions"
 | 
			
		||||
				arch-nspawn "$copydir" pacman --noconfirm -Swdd "${pkgnames[@]}"
 | 
			
		||||
				mapfile -t remotepkgs < <(pacman --config "$copydir"/etc/pacman.conf \
 | 
			
		||||
					--dbpath "$copydir"/var/lib/pacman \
 | 
			
		||||
					-Sddp "${pkgnames[@]}")
 | 
			
		||||
				break
 | 
			
		||||
			fi
 | 
			
		||||
		done
 | 
			
		||||
 | 
			
		||||
		msg2 "Checking packages"
 | 
			
		||||
		sudo -u "$makepkg_user" checkpkg --rmdir --warn
 | 
			
		||||
		sudo -u "$makepkg_user" checkpkg --rmdir --warn "${remotepkgs[@]/#file:\/\//}"
 | 
			
		||||
	fi
 | 
			
		||||
	true
 | 
			
		||||
fi
 | 
			
		||||
 
 | 
			
		||||
@@ -29,6 +29,7 @@ declare -a buildenv buildopts installed installpkgs
 | 
			
		||||
archiveurl='https://archive.archlinux.org/packages'
 | 
			
		||||
buildroot=/var/lib/archbuild/reproducible
 | 
			
		||||
chroot=testenv
 | 
			
		||||
diffoscope=0
 | 
			
		||||
 | 
			
		||||
parse_buildinfo() {
 | 
			
		||||
    local line var val
 | 
			
		||||
@@ -59,7 +60,7 @@ get_pkgfile() {
 | 
			
		||||
    local pkgname=${pkgfilebase%-*-*-*}
 | 
			
		||||
    local pkgfile ext
 | 
			
		||||
 | 
			
		||||
    for ext in .xz .zst ''; do
 | 
			
		||||
    for ext in .zst .xz ''; do
 | 
			
		||||
        pkgfile=${pkgfilebase}.pkg.tar${ext}
 | 
			
		||||
 | 
			
		||||
        for c in "${cache_dirs[@]}"; do
 | 
			
		||||
@@ -94,19 +95,21 @@ package, including the .PKGINFO as well as the buildinfo.
 | 
			
		||||
For more details see https://reproducible-builds.org/
 | 
			
		||||
 | 
			
		||||
OPTIONS
 | 
			
		||||
    -d            Run diffoscope if the package is unreproducible
 | 
			
		||||
    -c <dir>      Set pacman cache
 | 
			
		||||
    -M <file>     Location of a makepkg config file
 | 
			
		||||
    -h            Show this usage message
 | 
			
		||||
__EOF__
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
while getopts 'M:c:h' arg; do
 | 
			
		||||
        case "$arg" in
 | 
			
		||||
                M) archroot_args+=(-M "$OPTARG") ;;
 | 
			
		||||
                c) cache_dirs+=("$OPTARG") ;;
 | 
			
		||||
                h) usage; exit 0 ;;
 | 
			
		||||
                *|?) usage; exit 1 ;;
 | 
			
		||||
        esac
 | 
			
		||||
while getopts 'dM:c:h' arg; do
 | 
			
		||||
    case "$arg" in
 | 
			
		||||
        d) diffoscope=1 ;;
 | 
			
		||||
        M) archroot_args+=(-M "$OPTARG") ;;
 | 
			
		||||
        c) cache_dirs+=("$OPTARG") ;;
 | 
			
		||||
        h) usage; exit 0 ;;
 | 
			
		||||
        *|?) usage; exit 1 ;;
 | 
			
		||||
    esac
 | 
			
		||||
done
 | 
			
		||||
shift $((OPTIND - 1))
 | 
			
		||||
 | 
			
		||||
@@ -114,10 +117,13 @@ check_root
 | 
			
		||||
 | 
			
		||||
if [[ -n $1 ]]; then
 | 
			
		||||
    pkgfile="$1"
 | 
			
		||||
    if ! bsdtar -tqf "${pkgfile}" .BUILDINFO >/dev/null 2>&1; then
 | 
			
		||||
        error "file is not a valid pacman package: '%s'" "${pkgfile}"
 | 
			
		||||
        exit 1
 | 
			
		||||
    fi
 | 
			
		||||
    splitpkgs=("$@")
 | 
			
		||||
    for f in "${splitpkgs[@]}"; do
 | 
			
		||||
        if ! bsdtar -tqf "${f}" .BUILDINFO >/dev/null 2>&1; then
 | 
			
		||||
            error "file is not a valid pacman package: '%s'" "${f}"
 | 
			
		||||
            exit 1
 | 
			
		||||
        fi
 | 
			
		||||
    done
 | 
			
		||||
else
 | 
			
		||||
    error "no package file specified. Try '${BASH_SOURCE[0]##*/} -h' for more information. "
 | 
			
		||||
    exit 1
 | 
			
		||||
@@ -173,18 +179,26 @@ arch-nspawn "${buildroot}/${chroot}" \
 | 
			
		||||
    --bind="${PWD}:/startdir" \
 | 
			
		||||
    --bind="${SRCDEST}:/srcdest" \
 | 
			
		||||
    /chrootbuild -C --noconfirm --log --holdver --skipinteg
 | 
			
		||||
ret=$?
 | 
			
		||||
 | 
			
		||||
if (( $? == 0 )); then
 | 
			
		||||
if (( ${ret} == 0 )); then
 | 
			
		||||
    msg2 "built succeeded! built packages can be found in ${buildroot}/${chroot}/pkgdest"
 | 
			
		||||
    msg "comparing artifacts..."
 | 
			
		||||
    if cmp -s "${pkgfile}" "${buildroot}/${chroot}/pkgdest/${pkgfile##*/}"; then
 | 
			
		||||
        msg2 "Package successfully reproduced!"
 | 
			
		||||
        exit 0
 | 
			
		||||
    else
 | 
			
		||||
        warning "Package is not reproducible. :("
 | 
			
		||||
        sha256sum "${pkgfile}" "${buildroot}/${chroot}/pkgdest/${pkgfile##*/}"
 | 
			
		||||
    fi
 | 
			
		||||
 | 
			
		||||
    for pkgfile in "${splitpkgs[@]}"; do
 | 
			
		||||
        comparefiles=("${pkgfile}" "${buildroot}/${chroot}/pkgdest/${pkgfile##*/}")
 | 
			
		||||
        if cmp -s "${comparefiles[@]}"; then
 | 
			
		||||
            msg2 "Package '%s' successfully reproduced!" "${pkgfile}"
 | 
			
		||||
        else
 | 
			
		||||
            ret=1
 | 
			
		||||
            warning "Package '%s' is not reproducible. :(" "${pkgfile}"
 | 
			
		||||
            sha256sum "${comparefiles[@]}"
 | 
			
		||||
            if (( diffoscope )); then
 | 
			
		||||
                diffoscope "${comparefiles[@]}"
 | 
			
		||||
            fi
 | 
			
		||||
        fi
 | 
			
		||||
    done
 | 
			
		||||
fi
 | 
			
		||||
 | 
			
		||||
# the package either failed to build, or was unreproducible
 | 
			
		||||
exit 1
 | 
			
		||||
# return failure from chrootbuild, or the reproducibility status
 | 
			
		||||
exit ${ret}
 | 
			
		||||
 
 | 
			
		||||
@@ -81,12 +81,13 @@ fi
 | 
			
		||||
 | 
			
		||||
archbuild_cmd=("${repo}${archbuild_arch:+-$archbuild_arch}-build" "$@")
 | 
			
		||||
 | 
			
		||||
trap 'rm -rf $SRCPKGDEST' EXIT INT TERM QUIT
 | 
			
		||||
trap 'rm -rf $TEMPDIR' EXIT INT TERM QUIT
 | 
			
		||||
 | 
			
		||||
# Use a source-only tarball as an intermediate to transfer files. This
 | 
			
		||||
# guarantees the checksums are okay, and guarantees that all needed files are
 | 
			
		||||
# transferred, including local sources, install scripts, and changelogs.
 | 
			
		||||
export SRCPKGDEST=$(mktemp -d)
 | 
			
		||||
export TEMPDIR=$(mktemp -d --tmpdir offload-build.XXXXXXXXXX)
 | 
			
		||||
export SRCPKGDEST=${TEMPDIR}
 | 
			
		||||
makepkg --source || die "unable to make source package"
 | 
			
		||||
 | 
			
		||||
# Temporary cosmetic workaround makepkg if SRCDEST is set somewhere else
 | 
			
		||||
@@ -114,14 +115,17 @@ mapfile -t files < <(
 | 
			
		||||
            if [[ -f /usr/share/devtools/makepkg-'"${repo}"'-'"${arch}"'.conf ]]; then
 | 
			
		||||
                makepkg_config="/usr/share/devtools/makepkg-'"${repo}"'-'"${arch}"'.conf"
 | 
			
		||||
            fi &&
 | 
			
		||||
            makepkg --config <(cat "${makepkg_user_config}" "${makepkg_config}" 2>/dev/null) --packagelist
 | 
			
		||||
            makepkg --config <(cat "${makepkg_user_config}" "${makepkg_config}" 2>/dev/null) --packagelist &&
 | 
			
		||||
            printf "%s\n" "${temp}/PKGBUILD"
 | 
			
		||||
')
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
if (( ${#files[@]} )); then
 | 
			
		||||
    printf '%s\n' '' '-> copying files...'
 | 
			
		||||
    load_makepkg_config
 | 
			
		||||
    scp "${files[@]/#/$server:}" "${PKGDEST:-${PWD}}/"
 | 
			
		||||
    scp "${files[@]/#/$server:}" "${TEMPDIR}/"
 | 
			
		||||
    mv "${TEMPDIR}"/*.pkg.tar* "${PKGDEST:-${PWD}}/"
 | 
			
		||||
    mv "${TEMPDIR}/PKGBUILD" "${PWD}/"
 | 
			
		||||
else
 | 
			
		||||
    exit 1
 | 
			
		||||
fi
 | 
			
		||||
 
 | 
			
		||||
@@ -94,10 +94,11 @@ _offload_build_args=(
 | 
			
		||||
)
 | 
			
		||||
 | 
			
		||||
_makerepropkg_args=(
 | 
			
		||||
	'-d[Run diffoscope if the package is unreproducible]'
 | 
			
		||||
	'-c[Set pacman cache]:pacman_cache:_files -/'
 | 
			
		||||
	'-M[Location of a makepkg config file]:makepkg_config:_files -g "*.conf(.)"'
 | 
			
		||||
	'-h[Display usage]'
 | 
			
		||||
	'1:working_dir:_files -g "*.pkg.tar.*(.)"'
 | 
			
		||||
	'*:working_dir:_files -g "*.pkg.tar.*(.)"'
 | 
			
		||||
)
 | 
			
		||||
 | 
			
		||||
_devtools_completions_all_packages() {
 | 
			
		||||
 
 | 
			
		||||
		Reference in New Issue
	
	Block a user