summaryrefslogtreecommitdiff
path: root/src/fullpkg/fullpkg-build
blob: e824c2e0d3547d88aaa7ad1ae180d508c426563e (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
#!/usr/bin/env bash
# set -x # uncomment for debug
# Builds packages from ABS recursively. It tries to find dependencies that
# aren't built or need update and then makepkg them in order.

# TODO move __build to chroot

. libremessages
. $(librelib conf.sh)
load_files makepkg
load_files libretools
check_vars libretools FULLBUILDCMD || exit 1
# The following variables are actually optional
#check_vars libretools HOOKPKGBUILDMOD HOOKLOCALRELEASE || exit 1

## List packages on log that are on status
## usage: list_pkgs <status> <message>
#
## status: nonfree, built, failed, unstaged
list_pkgs() {
	msg="$2"
	local pkgs=($(grep "$1:" $build_dir/log)) && {
		msg "$2"
		printf '%s\n' "${pkgs[@]}" | cut -d: -f2
	}
}

## Check all build_dir, fails if one PKGBUILD is nonfree
check_nonfree() {
	find "$build_dir" -name PKGBUILD \
		-exec pkgbuild-check-nonfree {} +
	local s=$?
	pkgbuild-summarize-nonfree -q $s || return $s
}

# Removes a package from the buildorder
# $1 package name
# $2 buildorder file
remove_buildorder() {
	grep -Evw "${1}" ${2} > ${2}2
	mv -f ${2}2 ${2}

	return $?
}

succesfull_build() {

	if [[ "$RUN" != "$FULLBUILDCMD" ]]; then
		return 0 # Custom command or download sources
	fi

	if source .INFO && [[ -n "$repo" ]]; then

		if [[ ! -z "$HOOKLOCALRELEASE" ]]; then
			"$HOOKLOCALRELEASE" "$repo"
		fi

		msg "Updating pacman db and packages"
		sudo pacman -Sy || true

	fi

	echo "built:$(basename $PWD)" >>$build_dir/log
}

build_description() {
	list_pkgs "nonfree" "Those packages contain nonfree deps:"
	list_pkgs "built" "Those packages were built and staged:"
	list_pkgs "failed" "Those packages failed to build:"
	list_pkgs "unstaged" "Those packages couldn't be staged (missing reponame):"
}

__build() {
	pushd ${build_dir} >/dev/null

	build_packages=($(sort -gr $buildorder | cut -d: -f2)) # greater levels must be built first

	while [[ ${#build_packages[@]} -ge 1 ]]; do

		pushd "$build_dir/${build_packages[0]}" >/dev/null

		if [[ -n "${HOOKPKGBUILDMOD}" ]]; then
			${HOOKPKGBUILDMOD} || true
		fi

		eval "$RUN"; r=$?

		case $r in

			0) succesfull_build ;;

			*) error "There were errors while trying to build the package."
				echo "failed:$(basename $PWD)" >>$build_dir/log
				;;
		esac

		remove_buildorder "${build_packages[0]}" $buildorder || true

		# which is next package?
		build_packages=($(sort -gr $buildorder | cut -d: -f2))
		popd > /dev/null
	done

	popd >/dev/null
}

# End inmediately but print a useful message
trap_exit() {
	error "$@"
	warning "Leftover files left on $build_dir"
	mv .BUILDORDER BUILDORDER
	exit 1
}

# Trap signals from makepkg
set -E
trap 'trap_exit "(fullpkg-build) TERM signal caught. Exiting..."' TERM HUP QUIT
trap 'trap_exit "(fullpkg-build) Aborted by user! Exiting..."' INT
trap 'trap_exit "(fullpkg-build) An unknown error has occurred. Exiting..."' ERR

CLEANUP="false"
CHECKNONFREE="true"
RUN="$FULLBUILDCMD"
MESSAGE="$(_ 'Building packages')"

usage() {
	print "Usage: %s [OPTIONS] [BUILD_DIR]" "${0##*/}"
	print "Builds packages in BUILD_DIR, as set up by fullpkg-find"
	echo
	prose "Builds packages from BUILD_DIR; create BUILD_DIR using:"
	print '  $ fullpkg-find BUILD_DIR'
	echo
	prose "If no BUILD_DIR is specified, it uses the current directory."
	echo
	print "Options:"
	flag "-c" "Clean BUILD_DIR on succesfull build"
	flag "-N" "Don't check for freedom issues." #Also made by fullpkg-find
	flag "-r $(_ CMD)" "Use CMD instead of \${FULLBUILDCMD}"
	flag "-g" "Get sources for building packages on BUILD_DIR"
	flag "-h" "Show this message"
}

while getopts 'hNr:g' arg; do
	case $arg in
		h) usage; exit 0 ;;
		c) CLEAN ;;
		N) CHECKNONFREE="false" ;;
		r) RUN="$OPTARG"
			MESSAGE="$(_ 'Executing custom action')";;
		g) RUN='makepkg -g > /dev/null'
			MESSAGE="$(_ 'Downloading packages')";;
	esac
done

shift $(( OPTIND - 1 ))
build_dir="${1:-`pwd`}"
buildorder="${build_dir}/BUILDORDER"

if [[ ! -e "$buildorder" ]]; then
	error "This is not a build_dir. Make one using fullpkg."
	usage
	exit 1
else
	# backup BUILDORDER
	cp "$buildorder" "$build_dir/.BUILDORDER"
fi

if "$CHECKNONFREE"; then
	check_nonfree
fi

msg "$MESSAGE"
__build

if [[ "$RUN" != "$FULLBUILDCMD" ]]; then
	# Used for downloading or custom command
	mv "$build_dir/.BUILDORDER" "$buildorder"
	exit 0
elif "$CLEANUP"; then
	find "$build_dir" -mindepth 1 -delete
fi

build_description

plain "Test packages on and if they work fine librerelease."

exit 0