mirror of
				https://gitlab.archlinux.org/archlinux/devtools.git
				synced 2025-10-25 05:52:03 +02:00 
			
		
		
		
	Compare commits
	
		
			2 Commits
		
	
	
		
			v1.4.0
			...
			e9677a545a
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
|   | e9677a545a | ||
|   | f73b0510d1 | 
| @@ -19,7 +19,7 @@ shopt -s nullglob | |||||||
|  |  | ||||||
| default_makepkg_args=(--syncdeps --noconfirm --log --holdver --skipinteg) | default_makepkg_args=(--syncdeps --noconfirm --log --holdver --skipinteg) | ||||||
| makepkg_args=("${default_makepkg_args[@]}") | makepkg_args=("${default_makepkg_args[@]}") | ||||||
| verifysource_args=() | verifysource_args=(--syncdeps --noconfirm --log) | ||||||
| chrootdir= | chrootdir= | ||||||
| passeddir= | passeddir= | ||||||
| makepkg_user= | makepkg_user= | ||||||
| @@ -175,7 +175,7 @@ prepare_chroot() { | |||||||
| 	printf >>"$copydir/etc/passwd" 'builduser:x:%d:%d:builduser:/build:/bin/bash\n' "$builduser_uid" "$builduser_gid" | 	printf >>"$copydir/etc/passwd" 'builduser:x:%d:%d:builduser:/build:/bin/bash\n' "$builduser_uid" "$builduser_gid" | ||||||
| 	printf >>"$copydir/etc/shadow" 'builduser:!!:%d::::::\n' "$(( $(date -u +%s) / 86400 ))" | 	printf >>"$copydir/etc/shadow" 'builduser:!!:%d::::::\n' "$(( $(date -u +%s) / 86400 ))" | ||||||
|  |  | ||||||
| 	$install -d "$copydir"/{build,startdir,{pkg,srcpkg,src,log}dest} | 	$install -d "$copydir"/{build,startdir,{pkg,srcpkg,src,log}dest,verify/{gnupg,ssh}} | ||||||
|  |  | ||||||
| 	sed -e '/^MAKEFLAGS=/d' -e '/^PACKAGER=/d' -i "$copydir/etc/makepkg.conf" | 	sed -e '/^MAKEFLAGS=/d' -e '/^PACKAGER=/d' -i "$copydir/etc/makepkg.conf" | ||||||
| 	for x in BUILDDIR=/build PKGDEST=/pkgdest SRCPKGDEST=/srcpkgdest SRCDEST=/srcdest LOGDEST=/logdest \ | 	for x in BUILDDIR=/build PKGDEST=/pkgdest SRCPKGDEST=/srcpkgdest SRCDEST=/srcdest LOGDEST=/logdest \ | ||||||
| @@ -247,15 +247,10 @@ _chrootnamcap() { | |||||||
| 	done | 	done | ||||||
| } | } | ||||||
|  |  | ||||||
| download_sources() { | _download_sources() { | ||||||
| 	setup_workdir |  | ||||||
| 	chown "$makepkg_user:" "$WORKDIR" |  | ||||||
|  |  | ||||||
| 	# Ensure sources are downloaded | 	# Ensure sources are downloaded | ||||||
| 	sudo -u "$makepkg_user" --preserve-env=GNUPGHOME,SSH_AUTH_SOCK \ | 	sudo -u builduser env SRCDEST="/srcdest" GNUPGHOME="/verify/gnupg" SSH_AUTH_SOCK="/verify/ssh" \ | ||||||
| 		env SRCDEST="$SRCDEST" BUILDDIR="$WORKDIR" \ | 		bash -c "cd /startdir; makepkg --config=/etc/makepkg.conf --verifysource -o ${verifysource_args[*]}" | ||||||
| 		makepkg --config="$copydir/etc/makepkg.conf" --verifysource -o "${verifysource_args[@]}" || |  | ||||||
| 		die "Could not download sources." |  | ||||||
| } | } | ||||||
|  |  | ||||||
| move_logfiles() { | move_logfiles() { | ||||||
| @@ -352,6 +347,7 @@ umask 0022 | |||||||
| ORIG_HOME=$HOME | ORIG_HOME=$HOME | ||||||
| IFS=: read -r _ _ _ _ _ HOME _ < <(getent passwd "${SUDO_USER:-$USER}") | IFS=: read -r _ _ _ _ _ HOME _ < <(getent passwd "${SUDO_USER:-$USER}") | ||||||
| load_makepkg_config | load_makepkg_config | ||||||
|  | DEVTOOLS_GNUPGHOME="${GNUPGHOME:-$HOME/.gnupg}" | ||||||
| HOME=$ORIG_HOME | HOME=$ORIG_HOME | ||||||
|  |  | ||||||
| # Use PKGBUILD directory if these don't exist | # Use PKGBUILD directory if these don't exist | ||||||
| @@ -383,8 +379,6 @@ if [[ "$(id -u "$makepkg_user")" == 0 ]]; then | |||||||
| 	exit 1 | 	exit 1 | ||||||
| fi | fi | ||||||
|  |  | ||||||
| download_sources |  | ||||||
|  |  | ||||||
| prepare_chroot | prepare_chroot | ||||||
|  |  | ||||||
| nspawn_build_args=( | nspawn_build_args=( | ||||||
| @@ -396,6 +390,11 @@ nspawn_build_args=( | |||||||
| 	"${bindmounts_tmpfs[@]}" | 	"${bindmounts_tmpfs[@]}" | ||||||
| ) | ) | ||||||
|  |  | ||||||
|  | arch-nspawn "$copydir" \ | ||||||
|  | 	"${nspawn_build_args[@]}" --bind-ro="${DEVTOOLS_GNUPGHOME//:/\\:}:/verify/gnupg" --bind-ro="${SSH_AUTH_SOCK//:/\\:}:/verify/ssh" \ | ||||||
|  | 	bash -c "$(declare -f _download_sources); verifysource_args=(${verifysource_args[*]}); _download_sources" || | ||||||
|  | 	die "Could not download sources." | ||||||
|  |  | ||||||
| if arch-nspawn "$copydir" \ | if arch-nspawn "$copydir" \ | ||||||
| 	"${nspawn_build_args[@]}" \ | 	"${nspawn_build_args[@]}" \ | ||||||
| 	/chrootbuild "${makepkg_args[@]}" | 	/chrootbuild "${makepkg_args[@]}" | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user