blob: af693e8ccbbd1a393260e50a72a7105a7a874fd6 (
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
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
389
390
391
392
393
394
395
396
397
398
399
400
401
402
403
404
405
406
407
408
409
410
411
412
413
414
415
|
#!/bin/bash
# Trap these signals and kill ourselves if recieved
# Force ourselves to die if any of these signals are recieved
# most likely our controlling terminal is gone
trap "echo SIGTERM signal recieved killing $0 with pid $$;kill -9 $$" SIGTERM
trap "echo SIGHUP signal recieved killing $0 with pid $$;kill -9 $$" SIGHUP
trap "echo SIGKILL signal recieved killing $0 with pid $$;kill -9 $$" SIGKILL
#SIGINT interrupt character (usually Ctrl-C)
# * example: high-level sequence of events
# * my process (call it "P") is running
# * user types ctrl-c
# * kernel recognizes this and generates SIGINT signal
trap "echo SIGINT signal recieved killing $0 with pid $$;kill -9 $$" SIGINT
check_genkernel_version(){
if [ -x /usr/bin/genkernel ]
then
genkernel_version=$(genkernel --version)
genkernel_version_major=${genkernel_version%%.*}
genkernel_version_minor_sub=${genkernel_version#${genkernel_version_major}.}
genkernel_version_minor=${genkernel_version_minor_sub%%.*}
genkernel_version_sub=${genkernel_version##*.}
if [ -n "${genkernel_version}" -a "${genkernel_version_major}" -eq '3' -a "${genkernel_version_minor}" -ge '3' ]
then
echo "Genkernel version ${genkernel_version} found ... continuing"
else
echo "ERROR: Your genkernel version is too low in your seed stage. genkernel version 3.3.0"
echo "or greater is required."
exit 1
fi
else
exit 1
fi
}
get_libdir() {
ABI=$(portageq envvar ABI)
DEFAULT_ABI=$(portageq envvar DEFAULT_ABI)
LIBDIR_default=$(portageq envvar LIBDIR_default)
local abi
if [ $# -gt 0 ]
then
abi=${1}
elif [ -n "${ABI}" ]
then
abi=${ABI}
elif [ -n "${DEFAULT_ABI}" ]
then
abi=${DEFAULT_ABI}
else
abi="default"
fi
local var="LIBDIR_${abi}"
var=$(portageq envvar ${var})
echo ${var}
}
setup_myfeatures(){
setup_myemergeopts
export FEATURES="-news"
if [ -n "${clst_CCACHE}" ]
then
export clst_myfeatures="${clst_myfeatures} ccache"
clst_root_path=/ run_merge --oneshot --nodeps --noreplace dev-util/ccache || exit 1
fi
if [ -n "${clst_DISTCC}" ]
then
export clst_myfeatures="${clst_myfeatures} distcc"
export DISTCC_HOSTS="${clst_distcc_hosts}"
[ -e /etc/make.conf ] && \
echo 'USE="${USE} -avahi -gtk -gnome"' >> /etc/make.conf
# We install distcc to / on stage1, then use --noreplace, so we need to
# have some way to check if we need to reinstall distcc without being
# able to rely on USE, so we check for the distcc user and force a
# reinstall if it isn't found.
if [ "$(getent passwd distcc | cut -d: -f1)" != "distcc" ]
then
clst_root_path=/ run_merge --oneshot --nodeps sys-devel/distcc || exit 1
else
clst_root_path=/ run_merge --oneshot --nodeps --noreplace sys-devel/distcc || exit 1
fi
sed -i '/USE="${USE} -avahi -gtk -gnome"/d' /etc/make.conf
mkdir -p /etc/distcc
echo "${clst_distcc_hosts}" > /etc/distcc/hosts
# This sets up automatic cross-distcc-fu according to
# http://www.gentoo.org/doc/en/cross-compiling-distcc.xml
CHOST=$(portageq envvar CHOST)
LIBDIR=$(get_libdir)
cd /usr/${LIBDIR}/distcc/bin
rm cc gcc g++ c++ 2>/dev/null
echo -e '#!/bin/bash\nexec /usr/'${LIBDIR}'/distcc/bin/'${CHOST}'-g${0:$[-2]} "$@"' > ${CHOST}-wrapper
chmod a+x /usr/${LIBDIR}/distcc/bin/${CHOST}-wrapper
for i in cc gcc g++ c++; do ln -s ${CHOST}-wrapper ${i}; done
fi
if [ -n "${clst_ICECREAM}" ]
then
clst_root_path=/ run_merge --oneshot --nodeps --noreplace sys-devel/icecream || exit 1
# This sets up automatic cross-icecc-fu according to
# http://gentoo-wiki.com/HOWTO_Setup_An_ICECREAM_Compile_Cluster#Icecream_and_cross-compiling
CHOST=$(portageq envvar CHOST)
LIBDIR=$(get_libdir)
cd /usr/${LIBDIR}/icecc/bin
rm cc gcc g++ c++ 2>/dev/null
echo -e '#!/bin/bash\nexec /usr/'${LIBDIR}'/icecc/bin/'${CHOST}'-g${0:$[-2]} "$@"' > ${CHOST}-wrapper
chmod a+x ${CHOST}-wrapper
for i in cc gcc g++ c++; do ln -s ${CHOST}-wrapper ${i}; done
export PATH="/usr/lib/icecc/bin:${PATH}"
export PREROOTPATH="/usr/lib/icecc/bin"
fi
export FEATURES="${clst_myfeatures} -news"
}
setup_myemergeopts(){
if [ -n "${clst_VERBOSE}" ]
then
clst_myemergeopts="--verbose"
else
clst_myemergeopts="--quiet"
bootstrap_opts="${bootstrap_opts} -q"
fi
if [ -n "${clst_FETCH}" ]
then
export bootstrap_opts="${bootstrap_opts} -f"
export clst_myemergeopts="${clst_myemergeopts} -f"
elif [ -n "${clst_PKGCACHE}" ]
then
export clst_myemergeopts="${clst_myemergeopts} --usepkg --buildpkg --newuse"
export bootstrap_opts="${bootstrap_opts} -r"
fi
}
setup_binutils(){
if [ -x /usr/bin/binutils-config ]
then
mythang=$( cd /etc/env.d/binutils; ls ${clst_CHOST}-* | head -n 1 )
if [ -z "${mythang}" ]
then
mythang=1
fi
binutils-config ${mythang}; update_env_settings
fi
}
setup_gcc(){
if [ -x /usr/bin/gcc-config ]
then
mythang=$( cd /etc/env.d/gcc; ls ${clst_CHOST}-* | head -n 1 )
if [ -z "${mythang}" ]
then
mythang=1
fi
gcc-config ${mythang}; update_env_settings
fi
}
setup_pkgmgr(){
# We need to merge our package manager with USE="build" set in case it is
# portage to avoid frying our /etc/make.conf file. Otherwise, we could
# just let emerge system could merge it.
# Use --update or portage won't reinstall the same version.
[ -e /etc/make.conf ] && echo 'USE="${USE} build"' >> /etc/make.conf
run_merge --oneshot --nodeps --update sys-apps/portage
sed -i '/USE="${USE} build"/d' /etc/make.conf
}
cleanup_distcc() {
LIBDIR=$(get_libdir)
rm -rf /etc/distcc/hosts
for i in cc gcc c++ g++; do
rm -f /usr/${LIBDIR}/distcc/bin/${i}
ln -s /usr/bin/distcc /usr/${LIBDIR}/distcc/bin/${i}
done
rm -f /usr/${LIBDIR}/distcc/bin/*-wrapper
}
cleanup_icecream() {
LIBDIR=$(get_libdir)
for i in cc gcc c++ g++; do
rm -f /usr/${LIBDIR}/icecc/bin/${i}
ln -s /usr/bin/icecc /usr/${LIBDIR}/icecc/bin/${i}
done
rm -f /usr/${LIBDIR}/icecc/bin/*-wrapper
}
cleanup_stages() {
make_destpath
if [ -n "${clst_DISTCC}" ]
then
cleanup_distcc
fi
if [ -n "${clst_ICECREAM}" ]
then
cleanup_icecream
fi
case ${clst_target} in
stage3|system)
run_merge --depclean --with-bdeps=n
;;
*)
echo "Skipping depclean operation for ${clst_target}"
;;
esac
case ${clst_target} in
stage1|stage2|stage3)
rm -f /var/lib/portage/world
touch /var/lib/portage/world
;;
*)
echo "Skipping removal of world file for ${clst_target}"
;;
esac
rm -f /var/log/emerge.log /var/log/portage/elog/*
}
update_env_settings(){
[ -x /usr/sbin/env-update ] && /usr/sbin/env-update
source /etc/profile
[ -f /tmp/envscript ] && source /tmp/envscript
}
die() {
echo "$1"
exit 1
}
make_destpath() {
# ROOT is / by default, so remove any ROOT= settings from make.conf
sed -i '/ROOT=/d' /etc/make.conf
export ROOT=/
if [ "${1}" != "/" -a -n "${1}" ]
then
echo "ROOT=\"${1}\"" >> /etc/make.conf
export ROOT=${1}
fi
if [ ! -d ${ROOT} ]
then
install -d ${ROOT}
fi
}
run_merge() {
# Sets up the ROOT= parameter
# with no options ROOT=/
make_destpath ${clst_root_path}
export EMERGE_WARNING_DELAY=0
export CLEAN_DELAY=0
export EBEEP_IGNORE=0
export EPAUSE_IGNORE=0
export CONFIG_PROTECT="-*"
if [ -n "${clst_VERBOSE}" ]
then
echo "ROOT=${ROOT} emerge ${clst_myemergeopts} -pt $@" || exit 1
emerge ${clst_myemergeopts} -pt $@ || exit 3
echo "Press any key within 15 seconds to pause the build..."
read -s -t 15 -n 1
if [ $? -eq 0 ]
then
echo "Press any key to continue..."
read -s -n 1
fi
fi
echo "emerge ${clst_myemergeopts} $@" || exit 1
emerge ${clst_myemergeopts} $@ || exit 1
}
show_debug() {
if [ "${clst_DEBUG}" = "1" ]
then
unset PACKAGES
echo "DEBUG:"
echo "Profile/target info:"
echo "Profile inheritance:"
python -c 'import portage; print portage.settings.profiles'
echo
# TODO: make this work on non-portage
emerge --info
# TODO: grab our entire env
# <zmedico> to get see the ebuild env you can do something like:
# `set > /tmp/env_dump.${EBUILD_PHASE}` inside /etc/portage/bashrc
# XXX: Also, portageq does *not* source profile.bashrc at any time.
echo
echo "BOOTSTRAP_USE: $(portageq envvar BOOTSTRAP_USE)"
echo
echo "USE (profile): $(portageq envvar USE)"
echo "FEATURES (profile): $(portageq envvar FEATURES)"
echo
echo "ARCH: $(portageq envvar ARCH)"
echo "CHOST: $(portageq envvar CHOST)"
echo "CFLAGS: $(portageq envvar CFLAGS)"
echo
echo "These should be blank on non-multilib profiles."
echo "ABI: $(portageq envvar ABI)"
echo "DEFAULT_ABI: $(portageq envvar DEFAULT_ABI)"
echo "KERNEL_ABI: $(portageq envvar KERNEL_ABI)"
echo "LIBDIR: $(get_libdir)"
echo "MULTILIB_ABIS: $(portageq envvar MULTILIB_ABIS)"
echo "PROFILE_ARCH: $(portageq envvar PROFILE_ARCH)"
echo
fi
}
run_default_funcs() {
if [ "${RUN_DEFAULT_FUNCS}" != "no" ]
then
update_env_settings
setup_myfeatures
show_debug
fi
}
# Functions
# Copy libs of a executable in the chroot
function copy_libs() {
# Check if it's a dynamix exec
ldd ${1} > /dev/null 2>&1 || return
for lib in `ldd ${1} | awk '{ print $3 }'`
do
echo ${lib}
if [ -e ${lib} ]
then
if [ ! -e ${clst_root_path}/${lib} ]
then
copy_file ${lib}
[ -e "${clst_root_path}/${lib}" ] && \
strip -R .comment -R .note ${clst_root_path}/${lib} \
|| echo "WARNING : Cannot strip lib ${clst_root_path}/${lib} !"
fi
else
echo "WARNING : Some library was not found for ${lib} !"
fi
done
}
function copy_symlink() {
STACK=${2}
[ "${STACK}" = "" ] && STACK=16 || STACK=$((${STACK} - 1 ))
if [ ${STACK} -le 0 ]
then
echo "WARNING : ${TARGET} : too many levels of symbolic links !"
return
fi
[ ! -e ${clst_root_path}/`dirname ${1}` ] && \
mkdir -p ${clst_root_path}/`dirname ${1}`
[ ! -e ${clst_root_path}/${1} ] && \
cp -vfdp ${1} ${clst_root_path}/${1}
if [[ -n $(type -p realpath) ]]; then
TARGET=`realpath ${1}`
else
TARGET=`readlink -f ${1}`
fi
if [ -h ${TARGET} ]
then
copy_symlink ${TARGET} ${STACK}
else
copy_file ${TARGET}
fi
}
function copy_file() {
f="${1}"
if [ ! -e "${f}" ]
then
echo "WARNING : File not found : ${f}"
continue
fi
[ ! -e ${clst_root_path}/`dirname ${f}` ] && \
mkdir -p ${clst_root_path}/`dirname ${f}`
[ ! -e ${clst_root_path}/${f} ] && \
cp -vfdp ${f} ${clst_root_path}/${f}
if [ -x ${f} -a ! -h ${f} ]
then
copy_libs ${f}
strip -R .comment -R .note ${clst_root_path}/${f} > /dev/null 2>&1
elif [ -h ${f} ]
then
copy_symlink ${f}
fi
}
create_handbook_icon() {
# This function creates a local icon to the Gentoo Handbook
echo "[Desktop Entry]
Encoding=UTF-8
Version=1.0
Type=Link
URL=file:///mnt/cdrom/docs/handbook/html/index.html
Terminal=false
Name=Gentoo Linux Handbook
GenericName=Gentoo Linux Handbook
Comment=This is a link to the local copy of the Gentoo Linux Handbook.
Icon=text-editor" > /usr/share/applications/gentoo-handbook.desktop
}
# We do this everywhere, so why not put it in this script
run_default_funcs
|