mirror of
				https://gitlab.archlinux.org/archlinux/devtools.git
				synced 2025-10-30 23:34:43 +01:00 
			
		
		
		
	Compare commits
	
		
			28 Commits
		
	
	
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
|   | e10ce7fc70 | ||
|   | ff48401963 | ||
|   | 15f16162fb | ||
|   | fea14fa286 | ||
|   | 4bafd641ab | ||
|   | 58968cfaa2 | ||
|   | c8147a3512 | ||
|   | 76dec8507e | ||
|   | 9727b684e6 | ||
|   | e3fe7134e2 | ||
|   | 70d3c63b5c | ||
|   | eb6b0e3f11 | ||
|   | 69a3a0e7c0 | ||
|   | ca819a2357 | ||
|   | eb88a303b7 | ||
|   | 8f94d8118f | ||
|   | 882f5d0451 | ||
|   | f36c45e0c6 | ||
|   | 7fc22b9aba | ||
|   | 7fe0f68856 | ||
|   | f85fc32d78 | ||
|   | c5128dc45c | ||
|   | f1effdf989 | ||
|   | 38957783a2 | ||
|   | 5a7890f076 | ||
|   | ba45e06d3e | ||
|   | 393b9757cf | ||
|   | 3231cf8c36 | 
							
								
								
									
										5
									
								
								Makefile
									
									
									
									
									
								
							
							
						
						
									
										5
									
								
								Makefile
									
									
									
									
									
								
							| @@ -1,4 +1,4 @@ | ||||
| V=20150606 | ||||
| V=20170304 | ||||
|  | ||||
| PREFIX = /usr/local | ||||
|  | ||||
| @@ -112,6 +112,7 @@ dist: | ||||
| 	gpg --detach-sign --use-agent devtools-$(V).tar.gz | ||||
|  | ||||
| upload: | ||||
| 	scp devtools-$(V).tar.gz devtools-$(V).tar.gz.sig nymeria.archlinux.org:/srv/ftp/other/devtools/ | ||||
| 	scp devtools-$(V).tar.gz devtools-$(V).tar.gz.sig repos.archlinux.org:/srv/ftp/other/devtools/ | ||||
|  | ||||
| .PHONY: all clean install uninstall dist upload | ||||
|  | ||||
|   | ||||
| @@ -10,7 +10,7 @@ | ||||
|  | ||||
| m4_include(lib/common.sh) | ||||
|  | ||||
| CHROOT_VERSION='v3' | ||||
| CHROOT_VERSION='v4' | ||||
|  | ||||
| working_dir='' | ||||
|  | ||||
| @@ -53,7 +53,7 @@ else | ||||
| 	cache_dirs=("$cache_dir") | ||||
| fi | ||||
|  | ||||
| host_mirror=$(pacman -Sddp extra/devtools 2>/dev/null | sed -r 's#(.*/)extra/os/.*#\1$repo/os/$arch#') | ||||
| host_mirror=$(pacman --cachedir /doesnt/exist -Sddp extra/devtools 2>/dev/null | sed -r 's#(.*/)extra/os/.*#\1$repo/os/$arch#') | ||||
| [[ $host_mirror == *file://* ]] && host_mirror_path=$(echo "$host_mirror" | sed -r 's#file://(/.*)/\$repo/os/\$arch#\1#g') | ||||
|  | ||||
| # {{{ functions | ||||
| @@ -96,7 +96,7 @@ copy_hostconf | ||||
|  | ||||
| eval $(grep '^CARCH=' "$working_dir/etc/makepkg.conf") | ||||
|  | ||||
| exec ${CARCH:+setarch "$CARCH"} systemd-nspawn 2>/dev/null \ | ||||
| exec ${CARCH:+setarch "$CARCH"} systemd-nspawn -q \ | ||||
| 	-D "$working_dir" \ | ||||
| 	--register=no \ | ||||
| 	"${mount_args[@]}" \ | ||||
|   | ||||
| @@ -11,9 +11,9 @@ fi | ||||
|  | ||||
| case $scriptname in | ||||
| 	archco) | ||||
| 		SVNURL="svn+ssh://svn-packages@nymeria.archlinux.org/srv/repos/svn-packages/svn";; | ||||
| 		SVNURL="svn+ssh://svn-packages@repos.archlinux.org/srv/repos/svn-packages/svn";; | ||||
| 	communityco) | ||||
| 		SVNURL="svn+ssh://svn-community@nymeria.archlinux.org/srv/repos/svn-community/svn";; | ||||
| 		SVNURL="svn+ssh://svn-community@repos.archlinux.org/srv/repos/svn-community/svn";; | ||||
| 	*) | ||||
| 		die "Couldn't find svn url for %s" "$scriptname" | ||||
| 		;; | ||||
|   | ||||
| @@ -92,7 +92,7 @@ for _arch in ${arch[@]}; do | ||||
| done | ||||
|  | ||||
| if [[ -z $server ]]; then | ||||
| 	server='nymeria.archlinux.org' | ||||
| 	server='repos.archlinux.org' | ||||
| fi | ||||
|  | ||||
| if [[ -n $(svn status -q) ]]; then | ||||
|   | ||||
| @@ -29,7 +29,7 @@ case $scriptname in | ||||
| 		;; | ||||
| esac | ||||
|  | ||||
| server='nymeria.archlinux.org' | ||||
| server='repos.archlinux.org' | ||||
| source_svn="svn+ssh://svn-${source_name}@${server}/srv/repos/svn-${source_name}/svn" | ||||
| target_svn="svn+ssh://svn-${target_name}@${server}/srv/repos/svn-${target_name}/svn" | ||||
| source_dbscripts="/srv/repos/svn-${source_name}/dbscripts" | ||||
|   | ||||
| @@ -162,8 +162,6 @@ slock() { | ||||
| # usage: pkgver_equal( $pkgver1, $pkgver2 ) | ||||
| ## | ||||
| pkgver_equal() { | ||||
| 	local left right | ||||
|  | ||||
| 	if [[ $1 = *-* && $2 = *-* ]]; then | ||||
| 		# if both versions have a pkgrel, then they must be an exact match | ||||
| 		[[ $1 = "$2" ]] | ||||
| @@ -182,7 +180,7 @@ pkgver_equal() { | ||||
| find_cached_package() { | ||||
| 	local searchdirs=("$PWD" "$PKGDEST") results=() | ||||
| 	local targetname=$1 targetver=$2 targetarch=$3 | ||||
| 	local dir pkg pkgbasename pkgparts name ver rel arch size r results | ||||
| 	local dir pkg pkgbasename name ver rel arch r results | ||||
|  | ||||
| 	for dir in "${searchdirs[@]}"; do | ||||
| 		[[ -d $dir ]] || continue | ||||
|   | ||||
							
								
								
									
										169
									
								
								makechrootpkg.in
									
									
									
									
									
								
							
							
						
						
									
										169
									
								
								makechrootpkg.in
									
									
									
									
									
								
							| @@ -127,19 +127,16 @@ clean_temporary() { | ||||
| } | ||||
|  | ||||
| install_packages() { | ||||
| 	local pkgname | ||||
| 	local -a pkgnames | ||||
| 	local ret | ||||
|  | ||||
| 	for install_pkg in "${install_pkgs[@]}"; do | ||||
| 		pkgname="${install_pkg##*/}" | ||||
| 		cp "$install_pkg" "$copydir/$pkgname" | ||||
| 	pkgnames=("${install_pkgs[@]##*/}") | ||||
|  | ||||
| 		arch-nspawn "$copydir" \ | ||||
| 			"${bindmounts_ro[@]}" "${bindmounts_rw[@]}" \ | ||||
| 			pacman -U /$pkgname --noconfirm | ||||
| 		(( ret += !! $? )) | ||||
|  | ||||
| 		rm "$copydir/$pkgname" | ||||
| 	done | ||||
| 	cp -- "${install_pkgs[@]}" "$copydir/root/" | ||||
| 	arch-nspawn "$copydir" "${bindmounts_ro[@]}" "${bindmounts_rw[@]}" \ | ||||
| 		pacman -U --noconfirm -- "${pkgnames[@]/#//root/}" | ||||
| 	ret=$? | ||||
| 	rm -- "${pkgnames[@]/#/$copydir/root/}" | ||||
|  | ||||
| 	# If there is no PKGBUILD we are done | ||||
| 	[[ -f PKGBUILD ]] || exit $ret | ||||
| @@ -148,67 +145,37 @@ install_packages() { | ||||
| prepare_chroot() { | ||||
| 	$repack || rm -rf "$copydir/build" | ||||
|  | ||||
| 	mkdir -p "$copydir/build" | ||||
| 	if ! grep -q 'BUILDDIR="/build"' "$copydir/etc/makepkg.conf"; then | ||||
| 		echo 'BUILDDIR="/build"' >> "$copydir/etc/makepkg.conf" | ||||
| 	fi | ||||
|  | ||||
| 	# Read .makepkg.conf and gnupg pubring | ||||
| 	if [[ -r $USER_HOME/.gnupg/pubring.kbx ]]; then | ||||
| 		install -D "$USER_HOME/.gnupg/pubring.kbx" "$copydir/build/.gnupg/pubring.kbx" | ||||
| 	fi | ||||
| 	if [[ -r $USER_HOME/.gnupg/pubring.gpg ]]; then | ||||
| 		install -D "$USER_HOME/.gnupg/pubring.gpg" "$copydir/build/.gnupg/pubring.gpg" | ||||
| 	fi | ||||
|  | ||||
| 	mkdir -p "$copydir/pkgdest" | ||||
| 	if ! grep -q 'PKGDEST="/pkgdest"' "$copydir/etc/makepkg.conf"; then | ||||
| 		echo 'PKGDEST="/pkgdest"' >> "$copydir/etc/makepkg.conf" | ||||
| 	fi | ||||
|  | ||||
| 	mkdir -p "$copydir/srcpkgdest" | ||||
| 	if ! grep -q 'SRCPKGDEST="/srcpkgdest"' "$copydir/etc/makepkg.conf"; then | ||||
| 		echo 'SRCPKGDEST="/srcpkgdest"' >> "$copydir/etc/makepkg.conf" | ||||
| 	fi | ||||
|  | ||||
| 	mkdir -p "$copydir/logdest" | ||||
| 	if ! grep -q 'LOGDEST="/logdest"' "$copydir/etc/makepkg.conf"; then | ||||
| 		echo 'LOGDEST="/logdest"' >> "$copydir/etc/makepkg.conf" | ||||
| 	fi | ||||
|  | ||||
| 	# These two get bind-mounted read-only | ||||
| 	# XXX: makepkg dislikes having these dirs read-only, so separate them | ||||
| 	mkdir -p "$copydir/startdir" "$copydir/startdir_host" | ||||
| 	mkdir -p "$copydir/srcdest" "$copydir/srcdest_host" | ||||
| 	if ! grep -q 'SRCDEST="/srcdest"' "$copydir/etc/makepkg.conf"; then | ||||
| 		echo 'SRCDEST="/srcdest"' >> "$copydir/etc/makepkg.conf" | ||||
| 	fi | ||||
|  | ||||
| 	builduser_uid=${SUDO_UID:-$UID} | ||||
| 	local builduser_uid="${SUDO_UID:-$UID}" | ||||
| 	local builduser_gid="$(id -g "$builduser_uid")" | ||||
| 	local install="install -o $builduser_uid -g $builduser_gid" | ||||
| 	local x | ||||
|  | ||||
| 	# We can't use useradd without chrooting, otherwise it invokes PAM modules | ||||
| 	# which we might not be able to load (i.e. when building i686 packages on | ||||
| 	# an x86_64 host). | ||||
| 	printf 'builduser:x:%d:100:builduser:/:/usr/bin/nologin\n' "$builduser_uid" >>"$copydir/etc/passwd" | ||||
| 	chown -R "$builduser_uid" "$copydir"/{build,pkgdest,srcpkgdest,logdest,srcdest,startdir} | ||||
| 	sed -e '/^builduser:/d' -i "$copydir"/etc/{passwd,group} | ||||
| 	printf >>"$copydir/etc/group"  'builduser:x:%d:\n' $builduser_gid | ||||
| 	printf >>"$copydir/etc/passwd" 'builduser:x:%d:%d:builduser:/build:/bin/bash\n' $builduser_uid $builduser_gid | ||||
|  | ||||
| 	if [[ -n $MAKEFLAGS ]]; then | ||||
| 		sed -i '/^MAKEFLAGS=/d' "$copydir/etc/makepkg.conf" | ||||
| 		echo "MAKEFLAGS='${MAKEFLAGS}'" >> "$copydir/etc/makepkg.conf" | ||||
| 	fi | ||||
| 	$install -d "$copydir"/{build,build/.gnupg,startdir,{pkg,srcpkg,src,log}dest} | ||||
|  | ||||
| 	if [[ -n $PACKAGER ]]; then | ||||
| 		sed -i '/^PACKAGER=/d' "$copydir/etc/makepkg.conf" | ||||
| 		echo "PACKAGER='${PACKAGER}'" >> "$copydir/etc/makepkg.conf" | ||||
| 	fi | ||||
| 	for x in .gnupg/pubring.{kbx,gpg}; do | ||||
| 		[[ -r $USER_HOME/$x ]] || continue | ||||
| 		$install -m 644 "$USER_HOME/$x" "$copydir/build/$x" | ||||
| 	done | ||||
|  | ||||
| 	if [[ ! -f $copydir/etc/sudoers.d/builduser-pacman ]]; then | ||||
| 		cat > "$copydir/etc/sudoers.d/builduser-pacman" <<EOF | ||||
| Defaults env_keep += "HOME" | ||||
| 	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 \ | ||||
| 		"MAKEFLAGS='$MAKEFLAGS'" "PACKAGER='$PACKAGER'" | ||||
| 	do | ||||
| 		grep -q "^$x" "$copydir/etc/makepkg.conf" && continue | ||||
| 		echo "$x" >>"$copydir/etc/makepkg.conf" | ||||
| 	done | ||||
|  | ||||
| 	cat > "$copydir/etc/sudoers.d/builduser-pacman" <<EOF | ||||
| builduser ALL = NOPASSWD: /usr/bin/pacman | ||||
| EOF | ||||
| 		chmod 440 "$copydir/etc/sudoers.d/builduser-pacman" | ||||
| 	fi | ||||
| 	chmod 440 "$copydir/etc/sudoers.d/builduser-pacman" | ||||
|  | ||||
| 	# This is a little gross, but this way the script is recreated every time in the | ||||
| 	# working copy | ||||
| @@ -220,18 +187,28 @@ EOF | ||||
| 		printf ' || exit\n' | ||||
|  | ||||
| 		if $run_namcap; then | ||||
| 			cat <<'EOF' | ||||
| pacman -S --needed --noconfirm namcap | ||||
| for pkgfile in /startdir/PKGBUILD /pkgdest/*; do | ||||
| 	echo "Checking ${pkgfile##*/}" | ||||
| 	sudo -u builduser namcap "$pkgfile" 2>&1 | tee "/logdest/${pkgfile##*/}-namcap.log" | ||||
| done | ||||
| EOF | ||||
| 			declare -f _chrootnamcap | ||||
| 			printf '_chrootnamcap || exit\n' | ||||
| 		fi | ||||
| 	} >"$copydir/chrootbuild" | ||||
| 	chmod +x "$copydir/chrootbuild" | ||||
| } | ||||
|  | ||||
| # These functions aren't run in makechrootpkg, | ||||
| # so no global variables | ||||
| _chrootbuild() { | ||||
| 	. /etc/profile | ||||
| 	sudo -iu builduser bash -c 'cd /startdir; makepkg "$@"' -bash "$@" | ||||
| } | ||||
|  | ||||
| _chrootnamcap() { | ||||
| 	pacman -S --needed --noconfirm namcap | ||||
| 	for pkgfile in /startdir/PKGBUILD /pkgdest/*; do | ||||
| 		echo "Checking ${pkgfile##*/}" | ||||
| 		sudo -u builduser namcap "$pkgfile" 2>&1 | tee "/logdest/${pkgfile##*/}-namcap.log" | ||||
| 	done | ||||
| } | ||||
|  | ||||
| download_sources() { | ||||
| 	local builddir="$(mktemp -d)" | ||||
| 	chmod 1777 "$builddir" | ||||
| @@ -251,51 +228,15 @@ download_sources() { | ||||
| 	rm -rf $builddir | ||||
| } | ||||
|  | ||||
| _chrootbuild() { | ||||
| 	# This function isn't run in makechrootpkg, | ||||
| 	# so no global variables | ||||
|  | ||||
| 	. /etc/profile | ||||
| 	export HOME=/build | ||||
| 	shopt -s nullglob | ||||
|  | ||||
| 	# XXX: Workaround makepkg disliking read-only dirs | ||||
| 	ln -sft /srcdest /srcdest_host/* | ||||
| 	ln -sft /startdir /startdir_host/* | ||||
|  | ||||
| 	# XXX: Keep bzr and svn sources writable | ||||
| 	# Since makepkg 4.1.1 they get checked out via cp -a, copying the symlink | ||||
| 	for dir in /srcdest /startdir; do | ||||
| 		for vcs in bzr svn; do | ||||
| 			cd "$dir" | ||||
| 			for vcsdir in */.$vcs; do | ||||
| 				rm "${vcsdir%/.$vcs}" | ||||
| 				cp -a "${dir}_host/${vcsdir%/.$vcs}" . | ||||
| 				chown -R builduser "${vcsdir%/.$vcs}" | ||||
| 			done | ||||
| 		done | ||||
| 	done | ||||
|  | ||||
| 	cd /startdir | ||||
|  | ||||
| 	# XXX: Keep PKGBUILD writable for pkgver() | ||||
| 	rm PKGBUILD* | ||||
| 	cp /startdir_host/PKGBUILD* . | ||||
| 	chown builduser PKGBUILD* | ||||
|  | ||||
| 	# Safety check | ||||
| 	if [[ ! -w PKGBUILD ]]; then | ||||
| 		echo "Can't write to PKGBUILD!" | ||||
| 		exit 1 | ||||
| 	fi | ||||
|  | ||||
| 	sudo -u builduser makepkg "$@" | ||||
| } | ||||
|  | ||||
| move_products() { | ||||
| 	for pkgfile in "$copydir"/pkgdest/*; do | ||||
| 		chown "$src_owner" "$pkgfile" | ||||
| 		mv "$pkgfile" "$PKGDEST" | ||||
|  | ||||
| 		# Fix broken symlink because of temporary chroot PKGDEST /pkgdest | ||||
| 		if [[ "$PWD" != "$PKGDEST" && -L "$PWD/${pkgfile##*/}" ]]; then | ||||
| 			ln -sf "$PKGDEST/${pkgfile##*/}" | ||||
| 		fi | ||||
| 	done | ||||
|  | ||||
| 	for l in "$copydir"/logdest/*; do | ||||
| @@ -367,7 +308,7 @@ fi | ||||
|  | ||||
| umask 0022 | ||||
|  | ||||
| load_vars "$USER_HOME/.makepkg.conf" | ||||
| load_vars "${XDG_CONFIG_HOME:-$USER_HOME/.config}/pacman/makepkg.conf" || load_vars "$USER_HOME/.makepkg.conf" | ||||
| load_vars /etc/makepkg.conf | ||||
|  | ||||
| # Use PKGBUILD directory if these don't exist | ||||
| @@ -389,8 +330,8 @@ download_sources | ||||
| prepare_chroot | ||||
|  | ||||
| if arch-nspawn "$copydir" \ | ||||
| 	--bind-ro="$PWD:/startdir_host" \ | ||||
| 	--bind-ro="$SRCDEST:/srcdest_host" \ | ||||
| 	--bind="$PWD:/startdir" \ | ||||
| 	--bind="$SRCDEST:/srcdest" \ | ||||
| 	"${bindmounts_ro[@]}" "${bindmounts_rw[@]}" \ | ||||
| 	/chrootbuild | ||||
| then | ||||
|   | ||||
| @@ -19,7 +19,7 @@ DLAGENTS=('ftp::/usr/bin/curl -fC - --ftp-pasv --retry 3 --retry-delay 3 -o %o % | ||||
| # /usr/bin/lftpget -c | ||||
| # /usr/bin/wget | ||||
|  | ||||
| #-- The the package required by makepkg to download VCS sources | ||||
| #-- The package required by makepkg to download VCS sources | ||||
| #  Format: 'protocol::package' | ||||
| VCSCLIENTS=('bzr::bzr' | ||||
|             'git::git' | ||||
| @@ -37,8 +37,8 @@ CHOST="i686-pc-linux-gnu" | ||||
| # -march (or -mcpu) builds exclusively for an architecture | ||||
| # -mtune optimizes for an architecture, but builds for whole processor family | ||||
| CPPFLAGS="-D_FORTIFY_SOURCE=2" | ||||
| CFLAGS="-march=i686 -mtune=generic -O2 -pipe -fstack-protector-strong --param=ssp-buffer-size=4" | ||||
| CXXFLAGS="-march=i686 -mtune=generic -O2 -pipe -fstack-protector-strong --param=ssp-buffer-size=4" | ||||
| CFLAGS="-march=i686 -mtune=generic -O2 -pipe -fstack-protector-strong" | ||||
| CXXFLAGS="-march=i686 -mtune=generic -O2 -pipe -fstack-protector-strong" | ||||
| LDFLAGS="-Wl,-O1,--sort-common,--as-needed,-z,relro" | ||||
| #-- Make Flags: change this for DistCC/SMP systems | ||||
| #MAKEFLAGS="-j2" | ||||
| @@ -50,17 +50,16 @@ DEBUG_CXXFLAGS="-g -fvar-tracking-assignments" | ||||
| # BUILD ENVIRONMENT | ||||
| ######################################################################### | ||||
| # | ||||
| # Defaults: BUILDENV=(fakeroot !distcc color !ccache check !sign) | ||||
| # Defaults: BUILDENV=(!distcc color !ccache check !sign) | ||||
| #  A negated environment option will do the opposite of the comments below. | ||||
| # | ||||
| #-- fakeroot: Allow building packages as a non-root user | ||||
| #-- distcc:   Use the Distributed C/C++/ObjC compiler | ||||
| #-- color:    Colorize output messages | ||||
| #-- ccache:   Use ccache to cache compilation | ||||
| #-- check:    Run the check() function if present in the PKGBUILD | ||||
| #-- sign:     Generate PGP signature file | ||||
| # | ||||
| BUILDENV=(fakeroot !distcc color !ccache check !sign) | ||||
| BUILDENV=(!distcc color !ccache check !sign) | ||||
| # | ||||
| #-- If using DistCC, your MAKEFLAGS will also need modification. In addition, | ||||
| #-- specify a space-delimited list of hosts running in the DistCC cluster. | ||||
| @@ -74,7 +73,7 @@ BUILDENV=(fakeroot !distcc color !ccache check !sign) | ||||
| #   These are default values for the options=() settings | ||||
| ######################################################################### | ||||
| # | ||||
| # Default: OPTIONS=(strip docs !libtool !staticlibs emptydirs zipman purge !upx !debug) | ||||
| # Default: OPTIONS=(strip docs !libtool !staticlibs emptydirs zipman purge !optipng !upx !debug) | ||||
| #  A negated option will do the opposite of the comments below. | ||||
| # | ||||
| #-- strip:      Strip symbols from binaries/libraries | ||||
| @@ -85,9 +84,10 @@ BUILDENV=(fakeroot !distcc color !ccache check !sign) | ||||
| #-- zipman:     Compress manual (man and info) pages in MAN_DIRS with gzip | ||||
| #-- purge:      Remove files specified by PURGE_TARGETS | ||||
| #-- upx:        Compress binary executable files using UPX | ||||
| #-- optipng:    Optimize PNG images with optipng | ||||
| #-- debug:      Add debugging flags as specified in DEBUG_* variables | ||||
| # | ||||
| OPTIONS=(strip docs !libtool !staticlibs emptydirs zipman purge !upx !debug) | ||||
| OPTIONS=(strip docs !libtool !staticlibs emptydirs zipman purge !optipng !upx !debug) | ||||
|  | ||||
| #-- File integrity checks to use. Valid: md5, sha1, sha256, sha384, sha512 | ||||
| INTEGRITY_CHECK=(md5) | ||||
|   | ||||
| @@ -19,7 +19,7 @@ DLAGENTS=('ftp::/usr/bin/curl -fC - --ftp-pasv --retry 3 --retry-delay 3 -o %o % | ||||
| # /usr/bin/lftpget -c | ||||
| # /usr/bin/wget | ||||
|  | ||||
| #-- The the package required by makepkg to download VCS sources | ||||
| #-- The package required by makepkg to download VCS sources | ||||
| #  Format: 'protocol::package' | ||||
| VCSCLIENTS=('bzr::bzr' | ||||
|             'git::git' | ||||
| @@ -31,14 +31,14 @@ VCSCLIENTS=('bzr::bzr' | ||||
| ######################################################################### | ||||
| # | ||||
| CARCH="x86_64" | ||||
| CHOST="x86_64-unknown-linux-gnu" | ||||
| CHOST="x86_64-pc-linux-gnu" | ||||
|  | ||||
| #-- Compiler and Linker Flags | ||||
| # -march (or -mcpu) builds exclusively for an architecture | ||||
| # -mtune optimizes for an architecture, but builds for whole processor family | ||||
| CPPFLAGS="-D_FORTIFY_SOURCE=2" | ||||
| CFLAGS="-march=x86-64 -mtune=generic -O2 -pipe -fstack-protector-strong --param=ssp-buffer-size=4" | ||||
| CXXFLAGS="-march=x86-64 -mtune=generic -O2 -pipe -fstack-protector-strong --param=ssp-buffer-size=4" | ||||
| CFLAGS="-march=x86-64 -mtune=generic -O2 -pipe -fstack-protector-strong" | ||||
| CXXFLAGS="-march=x86-64 -mtune=generic -O2 -pipe -fstack-protector-strong" | ||||
| LDFLAGS="-Wl,-O1,--sort-common,--as-needed,-z,relro" | ||||
| #-- Make Flags: change this for DistCC/SMP systems | ||||
| #MAKEFLAGS="-j2" | ||||
| @@ -50,17 +50,16 @@ DEBUG_CXXFLAGS="-g -fvar-tracking-assignments" | ||||
| # BUILD ENVIRONMENT | ||||
| ######################################################################### | ||||
| # | ||||
| # Defaults: BUILDENV=(fakeroot !distcc color !ccache check !sign) | ||||
| # Defaults: BUILDENV=(!distcc color !ccache check !sign) | ||||
| #  A negated environment option will do the opposite of the comments below. | ||||
| # | ||||
| #-- fakeroot: Allow building packages as a non-root user | ||||
| #-- distcc:   Use the Distributed C/C++/ObjC compiler | ||||
| #-- color:    Colorize output messages | ||||
| #-- ccache:   Use ccache to cache compilation | ||||
| #-- check:    Run the check() function if present in the PKGBUILD | ||||
| #-- sign:     Generate PGP signature file | ||||
| # | ||||
| BUILDENV=(fakeroot !distcc color !ccache check !sign) | ||||
| BUILDENV=(!distcc color !ccache check !sign) | ||||
| # | ||||
| #-- If using DistCC, your MAKEFLAGS will also need modification. In addition, | ||||
| #-- specify a space-delimited list of hosts running in the DistCC cluster. | ||||
| @@ -74,7 +73,7 @@ BUILDENV=(fakeroot !distcc color !ccache check !sign) | ||||
| #   These are default values for the options=() settings | ||||
| ######################################################################### | ||||
| # | ||||
| # Default: OPTIONS=(strip docs !libtool !staticlibs emptydirs zipman purge !upx !debug) | ||||
| # Default: OPTIONS=(strip docs !libtool !staticlibs emptydirs zipman purge !optipng !upx !debug) | ||||
| #  A negated option will do the opposite of the comments below. | ||||
| # | ||||
| #-- strip:      Strip symbols from binaries/libraries | ||||
| @@ -85,9 +84,10 @@ BUILDENV=(fakeroot !distcc color !ccache check !sign) | ||||
| #-- zipman:     Compress manual (man and info) pages in MAN_DIRS with gzip | ||||
| #-- purge:      Remove files specified by PURGE_TARGETS | ||||
| #-- upx:        Compress binary executable files using UPX | ||||
| #-- optipng:    Optimize PNG images with optipng | ||||
| #-- debug:      Add debugging flags as specified in DEBUG_* variables | ||||
| # | ||||
| OPTIONS=(strip docs !libtool !staticlibs emptydirs zipman purge !upx !debug) | ||||
| OPTIONS=(strip docs !libtool !staticlibs emptydirs zipman purge !optipng !upx !debug) | ||||
|  | ||||
| #-- File integrity checks to use. Valid: md5, sha1, sha256, sha384, sha512 | ||||
| INTEGRITY_CHECK=(md5) | ||||
|   | ||||
| @@ -10,7 +10,7 @@ | ||||
|  | ||||
| m4_include(lib/common.sh) | ||||
|  | ||||
| CHROOT_VERSION='v3' | ||||
| CHROOT_VERSION='v4' | ||||
|  | ||||
| working_dir='' | ||||
|  | ||||
| @@ -72,9 +72,11 @@ pacstrap -GMcd ${pac_conf:+-C "$pac_conf"} "$working_dir" \ | ||||
|   "${cache_dirs[@]/#/--cachedir=}" "$@" || die 'Failed to install all packages' | ||||
|  | ||||
| printf '%s.UTF-8 UTF-8\n' en_US de_DE > "$working_dir/etc/locale.gen" | ||||
| echo 'LANG=C' > "$working_dir/etc/locale.conf" | ||||
| echo 'LANG=en_US.UTF-8' > "$working_dir/etc/locale.conf" | ||||
| echo "$CHROOT_VERSION" > "$working_dir/.arch-chroot" | ||||
|  | ||||
| systemd-machine-id-setup --root="$working_dir" | ||||
|  | ||||
| exec arch-nspawn \ | ||||
| 	${pac_conf:+-C "$pac_conf"} \ | ||||
| 	${makepkg_conf:+-M "$makepkg_conf"} \ | ||||
|   | ||||
| @@ -14,6 +14,7 @@ | ||||
| #CacheDir    = /var/cache/pacman/pkg/ | ||||
| #LogFile     = /var/log/pacman.log | ||||
| #GPGDir      = /etc/pacman.d/gnupg/ | ||||
| #HookDir     = /etc/pacman.d/hooks/ | ||||
| HoldPkg     = pacman glibc | ||||
| #XferCommand = /usr/bin/curl -C - -f %u > %o | ||||
| #XferCommand = /usr/bin/wget --passive-ftp -c -O %o %u | ||||
|   | ||||
| @@ -14,6 +14,7 @@ | ||||
| #CacheDir    = /var/cache/pacman/pkg/ | ||||
| #LogFile     = /var/log/pacman.log | ||||
| #GPGDir      = /etc/pacman.d/gnupg/ | ||||
| #HookDir     = /etc/pacman.d/hooks/ | ||||
| HoldPkg     = pacman glibc | ||||
| #XferCommand = /usr/bin/curl -C - -f %u > %o | ||||
| #XferCommand = /usr/bin/wget --passive-ftp -c -O %o %u | ||||
| @@ -72,6 +73,9 @@ LocalFileSigLevel = Optional | ||||
| [gnome-unstable] | ||||
| Include = /etc/pacman.d/mirrorlist | ||||
|  | ||||
| [staging] | ||||
| Include = /etc/pacman.d/mirrorlist | ||||
|  | ||||
| [testing] | ||||
| Include = /etc/pacman.d/mirrorlist | ||||
|  | ||||
| @@ -81,6 +85,9 @@ Include = /etc/pacman.d/mirrorlist | ||||
| [extra] | ||||
| Include = /etc/pacman.d/mirrorlist | ||||
|  | ||||
| [community-staging] | ||||
| Include = /etc/pacman.d/mirrorlist | ||||
|  | ||||
| [community-testing] | ||||
| Include = /etc/pacman.d/mirrorlist | ||||
|  | ||||
|   | ||||
| @@ -14,6 +14,7 @@ | ||||
| #CacheDir    = /var/cache/pacman/pkg/ | ||||
| #LogFile     = /var/log/pacman.log | ||||
| #GPGDir      = /etc/pacman.d/gnupg/ | ||||
| #HookDir     = /etc/pacman.d/hooks/ | ||||
| HoldPkg     = pacman glibc | ||||
| #XferCommand = /usr/bin/curl -C - -f %u > %o | ||||
| #XferCommand = /usr/bin/wget --passive-ftp -c -O %o %u | ||||
|   | ||||
| @@ -14,6 +14,7 @@ | ||||
| #CacheDir    = /var/cache/pacman/pkg/ | ||||
| #LogFile     = /var/log/pacman.log | ||||
| #GPGDir      = /etc/pacman.d/gnupg/ | ||||
| #HookDir     = /etc/pacman.d/hooks/ | ||||
| HoldPkg     = pacman glibc | ||||
| #XferCommand = /usr/bin/curl -C - -f %u > %o | ||||
| #XferCommand = /usr/bin/wget --passive-ftp -c -O %o %u | ||||
|   | ||||
| @@ -14,6 +14,7 @@ | ||||
| #CacheDir    = /var/cache/pacman/pkg/ | ||||
| #LogFile     = /var/log/pacman.log | ||||
| #GPGDir      = /etc/pacman.d/gnupg/ | ||||
| #HookDir     = /etc/pacman.d/hooks/ | ||||
| HoldPkg     = pacman glibc | ||||
| #XferCommand = /usr/bin/curl -C - -f %u > %o | ||||
| #XferCommand = /usr/bin/wget --passive-ftp -c -O %o %u | ||||
|   | ||||
| @@ -14,6 +14,7 @@ | ||||
| #CacheDir    = /var/cache/pacman/pkg/ | ||||
| #LogFile     = /var/log/pacman.log | ||||
| #GPGDir      = /etc/pacman.d/gnupg/ | ||||
| #HookDir     = /etc/pacman.d/hooks/ | ||||
| HoldPkg     = pacman glibc | ||||
| #XferCommand = /usr/bin/curl -C - -f %u > %o | ||||
| #XferCommand = /usr/bin/wget --passive-ftp -c -O %o %u | ||||
|   | ||||
| @@ -14,6 +14,7 @@ | ||||
| #CacheDir    = /var/cache/pacman/pkg/ | ||||
| #LogFile     = /var/log/pacman.log | ||||
| #GPGDir      = /etc/pacman.d/gnupg/ | ||||
| #HookDir     = /etc/pacman.d/hooks/ | ||||
| HoldPkg     = pacman glibc | ||||
| #XferCommand = /usr/bin/curl -C - -f %u > %o | ||||
| #XferCommand = /usr/bin/wget --passive-ftp -c -O %o %u | ||||
|   | ||||
| @@ -14,6 +14,7 @@ | ||||
| #CacheDir    = /var/cache/pacman/pkg/ | ||||
| #LogFile     = /var/log/pacman.log | ||||
| #GPGDir      = /etc/pacman.d/gnupg/ | ||||
| #HookDir     = /etc/pacman.d/hooks/ | ||||
| HoldPkg     = pacman glibc | ||||
| #XferCommand = /usr/bin/curl -C - -f %u > %o | ||||
| #XferCommand = /usr/bin/wget --passive-ftp -c -O %o %u | ||||
|   | ||||
| @@ -47,7 +47,7 @@ pkg_from_pkgbuild() { | ||||
| chrootdir="$1"; shift | ||||
| pkgs="$@" | ||||
|  | ||||
| SVNPATH='svn+ssh://nymeria.archlinux.org/srv/repos/svn-packages/svn' | ||||
| SVNPATH='svn+ssh://repos.archlinux.org/srv/repos/svn-packages/svn' | ||||
|  | ||||
| msg "Work will be done in $(pwd)/rebuilds" | ||||
|  | ||||
|   | ||||
		Reference in New Issue
	
	Block a user