blob: 2e18abe289eff6fd7c61d424cda4e5e07c0627de (
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
|
#!/bin/sh
mkdir -p /var/cache/tinderbox
reset_emergelog() {
rm -f /var/log/emerge.log
}
dent() {
# Ignore failure that might be caused by network being
# unavailable, the service being unavailable or things like those.
echo "$@" | bti || true
}
set -e
dent "#syncing anew upon request"
emerge --sync
echo > /etc/portage/package.mask/currentrun
./unavailable_installed.py | xargs -r emerge -C
reset_emergelog
emerge -u1 portage
emerge -u1 gcc
if fgrep -q '>>> emerge' /var/log/emerge.log; then
./update-gcc-asneeded.sh
fi
reset_emergelog
if emerge -u1 ghc haskell-updater &&
fgrep -q '>>> emerge' /var/log/emerge.log; then
dent "running #haskell-updater"
/usr/sbin/haskell-updater --upgrade
fi
reset_emergelog
if emerge -u1 dev-lang/ocaml &&
fgrep -q '>>> emerge' /var/log/emerge.log; then
dent "running #ocaml-rebuild"
/usr/sbin/ocaml-rebuild.sh -f
fi
emerge -u1 glibc bti screen avahi nfs-utils gentoolkit java-dep-check portage-utils
reset_emergelog
# Generate a new complete list, this will also produce the list of new
# dependencies to satisfy.
./tinderbox.py > /var/cache/tinderbox/list-complete
# Launch the fetch operation in background, saving the log (of both
# good results and failures).
nohup xargs -a /var/cache/tinderbox/list-complete emerge -fO --keep-going &> /var/log/tinderbox-fetch.log &
# Now replace the old queue with a new one, skipping everything that
# we wouldn't otherwise be merging (packages masked, removed, and
# similar).
mv /var/cache/tinderbox/queue /var/cache/tinderbox/queue.old
sort /var/cache/tinderbox/queue.old /var/cache/tinderbox/list-complete | uniq -d | sort -R > /var/cache/tinderbox/queue
|