joe: Bump package because of ncurses update
[ipfire-2.x.git] / make.sh
CommitLineData
df5e82b3 1#!/bin/bash
df5e82b3
MT
2############################################################################
3# #
f8e5510c 4# This file is part of the IPFire Firewall. #
df5e82b3 5# #
f8e5510c 6# IPFire is free software; you can redistribute it and/or modify #
df5e82b3
MT
7# it under the terms of the GNU General Public License as published by #
8# the Free Software Foundation; either version 2 of the License, or #
9# (at your option) any later version. #
10# #
f8e5510c 11# IPFire is distributed in the hope that it will be useful, #
df5e82b3
MT
12# but WITHOUT ANY WARRANTY; without even the implied warranty of #
13# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the #
14# GNU General Public License for more details. #
15# #
16# You should have received a copy of the GNU General Public License #
f8e5510c 17# along with IPFire; if not, write to the Free Software #
df5e82b3
MT
18# Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA #
19# #
29692af1 20# Copyright (C) 2007-2018 IPFire Team <info@ipfire.org>. #
df5e82b3
MT
21# #
22############################################################################
df5e82b3
MT
23#
24
e8ee3199
AF
25NAME="IPFire" # Software name
26SNAME="ipfire" # Short name
33513817 27VERSION="2.19" # Version number
2a20456f 28CORE="121" # Core Level (Filename)
f1051b49 29PAKFIRE_CORE="120" # Core Level (PAKFIRE)
595e89a8 30GIT_BRANCH=`git rev-parse --abbrev-ref HEAD` # Git Branch
e8ee3199
AF
31SLOGAN="www.ipfire.org" # Software slogan
32CONFIG_ROOT=/var/ipfire # Configuration rootdir
33NICE=10 # Nice level
34MAX_RETRIES=1 # prefetch/check loop
305a7b38 35BUILD_IMAGES=1 # Flash and Xen Downloader
15679d9f 36KVER=`grep --max-count=1 VER lfs/linux | awk '{ print $3 }'`
e8ee3199
AF
37GIT_TAG=$(git tag | tail -1) # Git Tag
38GIT_LASTCOMMIT=$(git log | head -n1 | cut -d" " -f2 |head -c8) # Last commit
628e8c3a 39
eb938697 40TOOLCHAINVER=20180213
03ad5f93 41
69a6ec55
MT
42###############################################################################
43#
44# Beautifying variables & presentation & input output interface
45#
46###############################################################################
47
f9783277
MT
48# Remember if the shell is interactive or not
49if [ -t 0 ] && [ -t 1 ]; then
50 INTERACTIVE=true
51else
52 INTERACTIVE=false
53fi
54
401a1edc
MT
55# Sets or adjusts pretty formatting variables
56resize_terminal() {
57 ## Screen Dimentions
58 # Find current screen size
59 COLUMNS=$(tput cols)
60
61 # When using remote connections, such as a serial port, stty size returns 0
62 if ! ${INTERACTIVE} || [ "${COLUMNS}" = "0" ]; then
63 COLUMNS=80
64 fi
69a6ec55 65
401a1edc
MT
66 # Measurements for positioning result messages
67 OPTIONS_WIDTH=20
68 TIME_WIDTH=12
69 STATUS_WIDTH=8
70 NAME_WIDTH=$(( COLUMNS - OPTIONS_WIDTH - TIME_WIDTH - STATUS_WIDTH ))
71 LINE_WIDTH=$(( COLUMNS - STATUS_WIDTH ))
72
e9a57acd
MT
73 TIME_COL=$(( NAME_WIDTH + OPTIONS_WIDTH ))
74 STATUS_COL=$(( TIME_COL + TIME_WIDTH ))
401a1edc 75}
69a6ec55 76
401a1edc
MT
77# Initially setup terminal
78resize_terminal
f9783277 79
401a1edc
MT
80# Call resize_terminal when terminal is being resized
81trap "resize_terminal" WINCH
69a6ec55
MT
82
83# Define color for messages
84BOLD="\\033[1;39m"
85DONE="\\033[1;32m"
86SKIP="\\033[1;34m"
87WARN="\\033[1;35m"
88FAIL="\\033[1;31m"
89NORMAL="\\033[0;39m"
90
bcb9dc13 91# New architecture variables
dc7d6b20 92HOST_ARCH="$(uname -m)"
94571564 93
69a6ec55
MT
94PWD=$(pwd)
95BASENAME=$(basename $0)
96
15679d9f
MT
97# Debian specific settings
98if [ ! -e /etc/debian_version ]; then
df5e82b3 99 FULLPATH=`which $0`
15679d9f 100else
df5e82b3
MT
101 if [ -x /usr/bin/realpath ]; then
102 FULLPATH=`/usr/bin/realpath $0`
103 else
104 echo "ERROR: Need to do apt-get install realpath"
105 exit 1
106 fi
15679d9f 107fi
df5e82b3 108
69a6ec55 109# This is the directory where make.sh is in
aecbe123 110export BASEDIR=$(echo $FULLPATH | sed "s/\/$BASENAME//g")
69a6ec55 111
15679d9f 112LOGFILE=$BASEDIR/log/_build.preparation.log
aecbe123 113export LOGFILE
15679d9f
MT
114DIR_CHK=$BASEDIR/cache/check
115mkdir $BASEDIR/log/ 2>/dev/null
df5e82b3 116
69a6ec55
MT
117system_processors() {
118 getconf _NPROCESSORS_ONLN 2>/dev/null || echo "1"
119}
120
121system_memory() {
122 local key val unit
123
124 while read -r key val unit; do
125 case "${key}" in
126 MemTotal:*)
127 # Convert to MB
128 echo "$(( ${val} / 1024 ))"
129 break
130 ;;
131 esac
132 done < /proc/meminfo
133}
134
135configure_build() {
136 local build_arch="${1}"
137
138 if [ "${build_arch}" = "default" ]; then
139 build_arch="$(configure_build_guess)"
140 fi
141
142 case "${build_arch}" in
143 x86_64)
144 BUILDTARGET="${build_arch}-unknown-linux-gnu"
145 CROSSTARGET="${build_arch}-cross-linux-gnu"
146 BUILD_PLATFORM="x86"
7520b95a 147 CFLAGS_ARCH="-m64 -mindirect-branch=thunk -mfunction-return=thunk -mtune=generic"
69a6ec55
MT
148 ;;
149
150 i586)
151 BUILDTARGET="${build_arch}-pc-linux-gnu"
152 CROSSTARGET="${build_arch}-cross-linux-gnu"
153 BUILD_PLATFORM="x86"
7520b95a 154 CFLAGS_ARCH="-march=i586 -mindirect-branch=thunk -mfunction-return=thunk -mtune=generic -fomit-frame-pointer"
69a6ec55
MT
155 ;;
156
157 aarch64)
158 BUILDTARGET="${build_arch}-unknown-linux-gnu"
159 CROSSTARGET="${build_arch}-cross-linux-gnu"
160 BUILD_PLATFORM="arm"
840f0b9f 161 CFLAGS_ARCH=""
69a6ec55
MT
162 ;;
163
164 armv7hl)
165 BUILDTARGET="${build_arch}-unknown-linux-gnueabi"
166 CROSSTARGET="${build_arch}-cross-linux-gnueabi"
167 BUILD_PLATFORM="arm"
168 CFLAGS_ARCH="-march=armv7-a -mfpu=vfpv3-d16 -mfloat-abi=hard"
169 ;;
170
171 armv5tel)
172 BUILDTARGET="${build_arch}-unknown-linux-gnueabi"
173 CROSSTARGET="${build_arch}-cross-linux-gnueabi"
174 BUILD_PLATFORM="arm"
175 CFLAGS_ARCH="-march=armv5te -mfloat-abi=soft -fomit-frame-pointer"
176 ;;
177
178 *)
179 exiterror "Cannot build for architure ${build_arch}"
180 ;;
181 esac
182
183 # Check if the QEMU helper is available if needed.
184 if qemu_is_required "${build_arch}"; then
185 local qemu_build_helper="$(qemu_find_build_helper_name "${build_arch}")"
186
187 if [ -n "${qemu_build_helper}" ]; then
188 QEMU_TARGET_HELPER="${qemu_build_helper}"
189 else
190 exiterror "Could not find a binfmt_misc helper entry for ${build_arch}"
191 fi
192 fi
193
194 BUILD_ARCH="${build_arch}"
195 TOOLS_DIR="/tools_${BUILD_ARCH}"
196
197 # Enables hardening
54114eb0 198 HARDENING_CFLAGS="-Wp,-D_FORTIFY_SOURCE=2 -Wp,-D_GLIBCXX_ASSERTIONS -fstack-protector-strong"
69a6ec55
MT
199
200 CFLAGS="-O2 -pipe -Wall -fexceptions -fPIC ${CFLAGS_ARCH}"
201 CXXFLAGS="${CFLAGS}"
202
203 # Determine parallelism
204 if [ -z "${MAKETUNING}" ]; then
205 # We assume that each process consumes about
206 # 192MB of memory. Therefore we find out how
207 # many processes fit into memory.
208 local mem_max=$(( ${HOST_MEM} / 192 ))
209
210 local processors="$(system_processors)"
cbcc1351 211 local cpu_max=$(( ${processors} + 1 ))
69a6ec55
MT
212
213 local parallelism
214 if [ ${mem_max} -lt ${cpu_max} ]; then
215 parallelism=${mem_max}
216 else
217 parallelism=${cpu_max}
218 fi
219
979f8700
AF
220 # limit to -j23 because perl will not build
221 # more
222 if [ ${parallelism} -gt 23 ]; then
223 parallelism=23
224 fi
225
69a6ec55
MT
226 MAKETUNING="-j${parallelism}"
227 fi
228}
229
230configure_build_guess() {
231 case "${HOST_ARCH}" in
232 x86_64|i686|i586)
233 echo "i586"
234 ;;
235
236 aarch64)
237 echo "aarch64"
238 ;;
239
240 armv7*|armv6*|armv5*)
241 echo "armv5tel"
242 ;;
243
244 *)
245 exiterror "Cannot guess build architecture"
246 ;;
247 esac
248}
249
f9783277
MT
250stdumount() {
251 umount $BASEDIR/build/sys 2>/dev/null;
252 umount $BASEDIR/build/dev/shm 2>/dev/null;
253 umount $BASEDIR/build/dev/pts 2>/dev/null;
254 umount $BASEDIR/build/dev 2>/dev/null;
255 umount $BASEDIR/build/proc 2>/dev/null;
256 umount $BASEDIR/build/install/mnt 2>/dev/null;
257 umount $BASEDIR/build/usr/src/cache 2>/dev/null;
258 umount $BASEDIR/build/usr/src/ccache 2>/dev/null;
259 umount $BASEDIR/build/usr/src/config 2>/dev/null;
260 umount $BASEDIR/build/usr/src/doc 2>/dev/null;
261 umount $BASEDIR/build/usr/src/html 2>/dev/null;
262 umount $BASEDIR/build/usr/src/langs 2>/dev/null;
263 umount $BASEDIR/build/usr/src/lfs 2>/dev/null;
264 umount $BASEDIR/build/usr/src/log 2>/dev/null;
265 umount $BASEDIR/build/usr/src/src 2>/dev/null;
266}
267
268now() {
269 date -u "+%s"
69a6ec55
MT
270}
271
f9783277
MT
272format_runtime() {
273 local seconds=${1}
274
275 if [ ${seconds} -ge 3600 ]; then
276 printf "%d:%02d:%02d\n" \
277 "$(( seconds / 3600 ))" \
278 "$(( seconds % 3600 / 60 ))" \
279 "$(( seconds % 3600 % 60 ))"
280 elif [ ${seconds} -ge 60 ]; then
281 printf "%d:%02d\n" \
282 "$(( seconds / 60 ))" \
283 "$(( seconds % 60 ))"
69a6ec55 284 else
f9783277 285 printf "%d\n" "${seconds}"
69a6ec55 286 fi
f9783277 287}
69a6ec55 288
f9783277
MT
289print_line() {
290 local line="$@"
69a6ec55 291
f9783277 292 printf "%-${LINE_WIDTH}s" "${line}"
69a6ec55
MT
293}
294
f9783277
MT
295_print_line() {
296 local status="${1}"
297 shift
69a6ec55 298
f9783277
MT
299 if ${INTERACTIVE}; then
300 printf "${!status}"
301 fi
69a6ec55 302
f9783277
MT
303 print_line "$@"
304
305 if ${INTERACTIVE}; then
306 printf "${NORMAL}"
307 fi
308}
309
310print_headline() {
311 _print_line BOLD "$@"
69a6ec55
MT
312}
313
f9783277
MT
314print_error() {
315 _print_line FAIL "$@"
316}
317
318print_package() {
319 local name="${1}"
320 shift
69a6ec55 321
f9783277
MT
322 local version="$(grep -E "^VER |^VER=|^VER " $BASEDIR/lfs/${name} | awk '{ print $3 }')"
323 local options="$@"
324
325 local string="${name}"
326 if [ -n "${version}" ] && [ "${version}" != "ipfire" ]; then
327 string="${string} (${version})"
328 fi
329
330 printf "%-$(( ${NAME_WIDTH} - 1 ))s " "${string}"
fa8c758e 331 printf "%$(( ${OPTIONS_WIDTH} - 1 ))s " "${options}"
f9783277
MT
332}
333
334print_runtime() {
335 local runtime=$(format_runtime $@)
336
337 if ${INTERACTIVE}; then
338 printf "\\033[${TIME_COL}G[ ${BOLD}%$(( ${TIME_WIDTH} - 4 ))s${NORMAL} ]" "${runtime}"
339 else
340 printf "[ %$(( ${TIME_WIDTH} - 4 ))s ]" "${runtime}"
69a6ec55 341 fi
f9783277
MT
342}
343
344print_status() {
345 local status="${1}"
346
347 local color="${!status}"
348
349 if ${INTERACTIVE}; then
350 printf "\\033[${STATUS_COL}G[${color-${BOLD}} %-$(( ${STATUS_WIDTH} - 4 ))s ${NORMAL}]\n" "${status}"
351 else
352 printf "[ %-$(( ${STATUS_WIDTH} - 4 ))s ]\n" "${status}"
69a6ec55 353 fi
f9783277 354}
69a6ec55 355
f9783277
MT
356print_build_stage() {
357 print_headline "$@"
358
359 # end line
360 printf "\n"
69a6ec55
MT
361}
362
f9783277
MT
363print_build_summary() {
364 local runtime=$(format_runtime $@)
365
366 print_line "*** Build finished in ${runtime}"
367 print_status DONE
69a6ec55
MT
368}
369
370exiterror() {
371 stdumount
372 for i in `seq 0 7`; do
373 if ( losetup /dev/loop${i} 2>/dev/null | grep -q "/install/images" ); then
374 losetup -d /dev/loop${i} 2>/dev/null
375 fi;
376 done
377
f9783277 378 # Dump logfile
66028310 379 if [ -n "${LOGFILE}" ] && [ -e "${LOGFILE}" ]; then
69a6ec55
MT
380 echo # empty line
381
382 local line
383 while read -r line; do
384 echo " ${line}"
385 done <<< "$(tail -n30 ${LOGFILE})"
386 fi
387
f9783277
MT
388 echo # empty line
389
390 local line
391 for line in "ERROR: $@" " Check ${LOGFILE} for errors if applicable"; do
392 print_error "${line}"
393 print_status FAIL
394 done
395
69a6ec55
MT
396 exit 1
397}
398
aecbe123
MT
399prepareenv() {
400 # Are we running the right shell?
54328605 401 if [ -z "${BASH}" ]; then
aecbe123
MT
402 exiterror "BASH environment variable is not set. You're probably running the wrong shell."
403 fi
404
405 if [ -z "${BASH_VERSION}" ]; then
406 exiterror "Not running BASH shell."
407 fi
408
409 # Trap on emergency exit
410 trap "exiterror 'Build process interrupted'" SIGINT SIGTERM SIGKILL SIGSTOP SIGQUIT
411
412 # Resetting our nice level
658232a6 413 if ! renice ${NICE} $$ >/dev/null; then
658232a6 414 exiterror "Failed to set nice level to ${NICE}"
aecbe123
MT
415 fi
416
417 # Checking if running as root user
658232a6 418 if [ $(id -u) -ne 0 ]; then
df7f30a1 419 exiterror "root privileges required for building"
aecbe123
MT
420 fi
421
422 # Checking for necessary temporary space
f9783277 423 print_line "Checking for necessary space on disk $BASE_DEV"
aecbe123
MT
424 BASE_DEV=`df -P -k $BASEDIR | tail -n 1 | awk '{ print $1 }'`
425 BASE_ASPACE=`df -P -k $BASEDIR | tail -n 1 | awk '{ print $4 }'`
426 if (( 2048000 > $BASE_ASPACE )); then
427 BASE_USPACE=`du -skx $BASEDIR | awk '{print $1}'`
428 if (( 2048000 - $BASE_USPACE > $BASE_ASPACE )); then
f9783277 429 print_status FAIL
aecbe123
MT
430 exiterror "Not enough temporary space available, need at least 2GB on $BASE_DEV"
431 fi
432 else
f9783277 433 print_status DONE
aecbe123
MT
434 fi
435
436 # Set umask
437 umask 022
438
439 # Set LFS Directory
440 LFS=$BASEDIR/build
441
aecbe123
MT
442 # Setup environment
443 set +h
444 LC_ALL=POSIX
445 export LFS LC_ALL CFLAGS CXXFLAGS MAKETUNING
446 unset CC CXX CPP LD_LIBRARY_PATH LD_PRELOAD
447
448 # Make some extra directories
449 mkdir -p "${BASEDIR}/build${TOOLS_DIR}" 2>/dev/null
450 mkdir -p $BASEDIR/build/{etc,usr/src} 2>/dev/null
451 mkdir -p $BASEDIR/build/{dev/{shm,pts},proc,sys}
452 mkdir -p $BASEDIR/{cache,ccache} 2>/dev/null
453 mkdir -p $BASEDIR/build/usr/src/{cache,config,doc,html,langs,lfs,log,src,ccache}
454
455 mknod -m 600 $BASEDIR/build/dev/console c 5 1 2>/dev/null
456 mknod -m 666 $BASEDIR/build/dev/null c 1 3 2>/dev/null
457
458 # Make all sources and proc available under lfs build
459 mount --bind /dev $BASEDIR/build/dev
460 mount --bind /dev/pts $BASEDIR/build/dev/pts
461 mount --bind /dev/shm $BASEDIR/build/dev/shm
462 mount --bind /proc $BASEDIR/build/proc
463 mount --bind /sys $BASEDIR/build/sys
464 mount --bind $BASEDIR/cache $BASEDIR/build/usr/src/cache
465 mount --bind $BASEDIR/ccache $BASEDIR/build/usr/src/ccache
466 mount --bind $BASEDIR/config $BASEDIR/build/usr/src/config
467 mount --bind $BASEDIR/doc $BASEDIR/build/usr/src/doc
468 mount --bind $BASEDIR/html $BASEDIR/build/usr/src/html
469 mount --bind $BASEDIR/langs $BASEDIR/build/usr/src/langs
470 mount --bind $BASEDIR/lfs $BASEDIR/build/usr/src/lfs
471 mount --bind $BASEDIR/log $BASEDIR/build/usr/src/log
472 mount --bind $BASEDIR/src $BASEDIR/build/usr/src/src
473
474 # Run LFS static binary creation scripts one by one
475 export CCACHE_DIR=$BASEDIR/ccache
476 export CCACHE_COMPRESS=1
477 export CCACHE_COMPILERCHECK="string:toolchain-${TOOLCHAINVER} ${BUILD_ARCH}"
478
479 # Remove pre-install list of installed files in case user erase some files before rebuild
480 rm -f $BASEDIR/build/usr/src/lsalr 2>/dev/null
481
482 # Prepare string for /etc/system-release.
483 SYSTEM_RELEASE="${NAME} ${VERSION} (${BUILD_ARCH})"
484 if [ "$(git status -s | wc -l)" == "0" ]; then
485 GIT_STATUS=""
486 else
487 GIT_STATUS="-dirty"
488 fi
489 case "$GIT_BRANCH" in
490 core*|beta?|rc?)
491 SYSTEM_RELEASE="${SYSTEM_RELEASE} - $GIT_BRANCH$GIT_STATUS"
492 ;;
493 *)
494 SYSTEM_RELEASE="${SYSTEM_RELEASE} - Development Build: $GIT_BRANCH/$GIT_LASTCOMMIT$GIT_STATUS"
495 ;;
496 esac
497}
498
69a6ec55
MT
499enterchroot() {
500 # Install QEMU helper, if needed
501 qemu_install_helper
502
503 local PATH="${TOOLS_DIR}/ccache/bin:/bin:/usr/bin:/sbin:/usr/sbin:${TOOLS_DIR}/bin"
504
505 PATH="${PATH}" chroot ${LFS} env -i \
506 HOME="/root" \
507 TERM="${TERM}" \
508 PS1="${PS1}" \
509 PATH="${PATH}" \
510 SYSTEM_RELEASE="${SYSTEM_RELEASE}" \
511 PAKFIRE_CORE="${PAKFIRE_CORE}" \
512 NAME="${NAME}" \
513 SNAME="${SNAME}" \
514 VERSION="${VERSION}" \
515 CORE="${CORE}" \
516 SLOGAN="${SLOGAN}" \
517 TOOLS_DIR="${TOOLS_DIR}" \
518 CONFIG_ROOT="${CONFIG_ROOT}" \
519 CFLAGS="${CFLAGS} ${HARDENING_CFLAGS}" \
520 CXXFLAGS="${CXXFLAGS} ${HARDENING_CFLAGS}" \
521 BUILDTARGET="${BUILDTARGET}" \
522 CROSSTARGET="${CROSSTARGET}" \
523 BUILD_ARCH="${BUILD_ARCH}" \
524 BUILD_PLATFORM="${BUILD_PLATFORM}" \
525 CCACHE_DIR=/usr/src/ccache \
526 CCACHE_COMPRESS="${CCACHE_COMPRESS}" \
527 CCACHE_COMPILERCHECK="${CCACHE_COMPILERCHECK}" \
528 KVER="${KVER}" \
0d7a6f03 529 XZ_OPT="${XZ_OPT}" \
69a6ec55
MT
530 $(fake_environ) \
531 $(qemu_environ) \
532 "$@"
533}
534
535entershell() {
536 if [ ! -e $BASEDIR/build/usr/src/lfs/ ]; then
537 exiterror "No such file or directory: $BASEDIR/build/usr/src/lfs/"
538 fi
539
540 echo "Entering to a shell inside LFS chroot, go out with exit"
ab8464f4 541 local PS1="ipfire build chroot (${BUILD_ARCH}) \u:\w\$ "
69a6ec55
MT
542
543 if enterchroot bash -i; then
544 stdumount
545 else
f9783277 546 print_status FAIL
69a6ec55
MT
547 exiterror "chroot error"
548 fi
549}
550
551lfsmakecommoncheck() {
552 # Script present?
553 if [ ! -f $BASEDIR/lfs/$1 ]; then
554 exiterror "No such file or directory: $BASEDIR/$1"
555 fi
556
f9783277
MT
557 # Print package name and version
558 print_package $@
69a6ec55
MT
559
560 # Check if this package is supported by our architecture.
561 # If no SUP_ARCH is found, we assume the package can be built for all.
562 if grep "^SUP_ARCH" ${BASEDIR}/lfs/${1} >/dev/null; then
563 # Check if package supports ${BUILD_ARCH} or all architectures.
564 if ! grep -E "^SUP_ARCH.*${BUILD_ARCH}|^SUP_ARCH.*all" ${BASEDIR}/lfs/${1} >/dev/null; then
405ee2b4 565 print_runtime 0
f9783277 566 print_status SKIP
69a6ec55
MT
567 return 1
568 fi
569 fi
570
571 # Script slipped?
572 local i
573 for i in $SKIP_PACKAGE_LIST
574 do
575 if [ "$i" == "$1" ]; then
f9783277 576 print_status SKIP
69a6ec55
MT
577 return 1;
578 fi
579 done
580
581 echo -ne "`date -u '+%b %e %T'`: Building $* " >> $LOGFILE
582
583 cd $BASEDIR/lfs && make -s -f $* LFS_BASEDIR=$BASEDIR BUILD_ARCH="${BUILD_ARCH}" \
584 MESSAGE="$1\t " download >> $LOGFILE 2>&1
585 if [ $? -ne 0 ]; then
586 exiterror "Download error in $1"
587 fi
588
589 cd $BASEDIR/lfs && make -s -f $* LFS_BASEDIR=$BASEDIR BUILD_ARCH="${BUILD_ARCH}" \
590 MESSAGE="$1\t md5sum" md5 >> $LOGFILE 2>&1
591 if [ $? -ne 0 ]; then
592 exiterror "md5sum error in $1, check file in cache or signature"
593 fi
594
595 return 0 # pass all!
596}
597
598lfsmake1() {
599 lfsmakecommoncheck $*
600 [ $? == 1 ] && return 0
601
69a6ec55
MT
602 cd $BASEDIR/lfs && env -i \
603 PATH="${TOOLS_DIR}/ccache/bin:${TOOLS_DIR}/bin:$PATH" \
604 CCACHE_DIR="${CCACHE_DIR}" \
605 CCACHE_COMPRESS="${CCACHE_COMPRESS}" \
606 CCACHE_COMPILERCHECK="${CCACHE_COMPILERCHECK}" \
607 CFLAGS="${CFLAGS}" \
608 CXXFLAGS="${CXXFLAGS}" \
609 MAKETUNING="${MAKETUNING}" \
610 make -f $* \
611 TOOLCHAIN=1 \
612 TOOLS_DIR="${TOOLS_DIR}" \
613 CROSSTARGET="${CROSSTARGET}" \
614 BUILDTARGET="${BUILDTARGET}" \
615 BUILD_ARCH="${BUILD_ARCH}" \
616 BUILD_PLATFORM="${BUILD_PLATFORM}" \
617 LFS_BASEDIR="${BASEDIR}" \
618 ROOT="${LFS}" \
619 KVER="${KVER}" \
f9783277 620 install >> $LOGFILE 2>&1 &
69a6ec55 621
f9783277
MT
622 if ! wait_until_finished $!; then
623 print_status FAIL
624 exiterror "Building $*"
69a6ec55
MT
625 fi
626
f9783277 627 print_status DONE
69a6ec55
MT
628}
629
630lfsmake2() {
631 lfsmakecommoncheck $*
632 [ $? == 1 ] && return 0
633
69a6ec55
MT
634 local PS1='\u:\w$ '
635
636 enterchroot \
ce9264a1 637 ${EXTRA_PATH}bash -x -c "cd /usr/src/lfs && \
69a6ec55
MT
638 MAKETUNING=${MAKETUNING} \
639 make -f $* \
640 LFS_BASEDIR=/usr/src install" \
f9783277 641 >> ${LOGFILE} 2>&1 &
69a6ec55 642
f9783277
MT
643 if ! wait_until_finished $!; then
644 print_status FAIL
645 exiterror "Building $*"
69a6ec55
MT
646 fi
647
f9783277 648 print_status DONE
69a6ec55
MT
649}
650
651ipfiredist() {
652 lfsmakecommoncheck $*
653 [ $? == 1 ] && return 0
654
69a6ec55
MT
655 local PS1='\u:\w$ '
656
657 enterchroot \
658 bash -x -c "cd /usr/src/lfs && make -f $* LFS_BASEDIR=/usr/src dist" \
f9783277 659 >> ${LOGFILE} 2>&1 &
69a6ec55 660
f9783277
MT
661 if ! wait_until_finished $!; then
662 print_status FAIL
663 exiterror "Packaging $*"
664 fi
69a6ec55 665
f9783277
MT
666 print_status DONE
667}
668
669wait_until_finished() {
670 local pid=${1}
671
672 local start_time=$(now)
673
674 # Show progress
675 if ${INTERACTIVE}; then
676 # Wait a little just in case the process
677 # has finished very quickly.
678 sleep 0.1
679
680 local runtime
681 while kill -0 ${pid} 2>/dev/null; do
682 print_runtime $(( $(now) - ${start_time} ))
683
684 # Wait a little
685 sleep 1
686 done
69a6ec55 687 fi
f9783277
MT
688
689 # Returns the exit code of the child process
690 wait ${pid}
691 local ret=$?
692
693 if ! ${INTERACTIVE}; then
694 print_runtime $(( $(now) - ${start_time} ))
695 fi
696
697 return ${ret}
69a6ec55
MT
698}
699
700fake_environ() {
701 [ -e "${BASEDIR}/build${TOOLS_DIR}/lib/libpakfire_preload.so" ] || return
702
703 local env="LD_PRELOAD=${TOOLS_DIR}/lib/libpakfire_preload.so"
704
705 # Fake kernel version, because some of the packages do not compile
706 # with kernel 3.0 and later.
707 env="${env} UTS_RELEASE=${KVER}"
708
709 # Fake machine version.
710 env="${env} UTS_MACHINE=${BUILD_ARCH}"
711
712 echo "${env}"
713}
714
715qemu_environ() {
716 local env
717
718 # Don't add anything if qemu is not used.
719 if ! qemu_is_required; then
720 return
721 fi
722
723 # Set default qemu options
724 case "${BUILD_ARCH}" in
725 arm*)
726 QEMU_CPU="${QEMU_CPU:-cortex-a9}"
727
728 env="${env} QEMU_CPU=${QEMU_CPU}"
729 ;;
730 esac
731
732 # Enable QEMU strace
733 #env="${env} QEMU_STRACE=1"
734
735 echo "${env}"
736}
737
738qemu_is_required() {
739 local build_arch="${1}"
740
741 if [ -z "${build_arch}" ]; then
742 build_arch="${BUILD_ARCH}"
743 fi
744
745 case "${HOST_ARCH},${build_arch}" in
746 x86_64,arm*|i?86,arm*|i?86,x86_64)
747 return 0
748 ;;
749 *)
750 return 1
751 ;;
752 esac
753}
754
755qemu_install_helper() {
756 # Do nothing, if qemu is not required
757 if ! qemu_is_required; then
758 return 0
759 fi
760
761 if [ ! -e /proc/sys/fs/binfmt_misc/status ]; then
762 exiterror "binfmt_misc not mounted. QEMU_TARGET_HELPER not useable."
763 fi
764
765 if [ ! $(cat /proc/sys/fs/binfmt_misc/status) = 'enabled' ]; then
766 exiterror "binfmt_misc not enabled. QEMU_TARGET_HELPER not useable."
767 fi
768
769
770 if [ -z "${QEMU_TARGET_HELPER}" ]; then
771 exiterror "QEMU_TARGET_HELPER not set"
772 fi
773
774 # Check if the helper is already installed.
775 if [ -x "${LFS}${QEMU_TARGET_HELPER}" ]; then
776 return 0
777 fi
778
779 # Try to find a suitable binary that we can install
780 # to the build environment.
781 local file
782 for file in "${QEMU_TARGET_HELPER}" "${QEMU_TARGET_HELPER}-static"; do
783 # file must exist and be executable.
784 [ -x "${file}" ] || continue
785
786 # Must be static.
787 file_is_static "${file}" || continue
788
789 local dirname="${LFS}$(dirname "${file}")"
790 mkdir -p "${dirname}"
791
792 install -m 755 "${file}" "${LFS}${QEMU_TARGET_HELPER}"
793 return 0
794 done
795
796 exiterror "Could not find a statically-linked QEMU emulator: ${QEMU_TARGET_HELPER}"
797}
798
799qemu_find_build_helper_name() {
800 local build_arch="${1}"
801
802 local magic
803 case "${build_arch}" in
804 arm*)
805 magic="7f454c4601010100000000000000000002002800"
806 ;;
807 x86_64)
808 magic="7f454c4602010100000000000000000002003e00"
809 ;;
810 esac
811
812 [ -z "${magic}" ] && return 1
813
814 local file
815 for file in /proc/sys/fs/binfmt_misc/*; do
816 # skip write only register entry
817 [ $(basename "${file}") = "register" ] && continue
818 # Search for the file with the correct magic value.
819 grep -qE "^magic ${magic}$" "${file}" || continue
820
821 local interpreter="$(grep "^interpreter" "${file}" | awk '{ print $2 }')"
822
823 [ -n "${interpreter}" ] || continue
824 [ "${interpreter:0:1}" = "/" ] || continue
825 [ -x "${interpreter}" ] || continue
826
827 echo "${interpreter}"
828 return 0
829 done
830
831 return 1
832}
833
834file_is_static() {
835 local file="${1}"
836
837 file ${file} 2>/dev/null | grep -q "statically linked"
838}
839
840update_language_list() {
841 local path="${1}"
842
843 local lang
844 for lang in ${path}/*.po; do
845 lang="$(basename "${lang}")"
846 echo "${lang%*.po}"
847 done | sort -u > "${path}/LINGUAS"
848}
849
a98ab1d7
MT
850# Load configuration file
851if [ -f .config ]; then
852 . .config
853fi
854
813659f2
MT
855# TARGET_ARCH is BUILD_ARCH now
856if [ -n "${TARGET_ARCH}" ]; then
857 BUILD_ARCH="${TARGET_ARCH}"
858 unset TARGET_ARCH
859fi
860
5190eea2
MT
861# Get the amount of memory in this build system
862HOST_MEM=$(system_memory)
863
0d7a6f03 864# Checking host memory, tuning XZ_OPT
5852ad2d
MT
865if [ ${HOST_MEM} -lt 1024 ]; then
866 exiterror "You will need more than 1GB or host memory to run the build"
0d7a6f03
MF
867fi
868
c8453e87 869# We compress archives with "xz -8", using all cores and up to 70% of memory
5852ad2d 870XZ_MEM="$(( HOST_MEM * 7 / 10 ))MiB"
c8453e87 871XZ_OPT="-T$(system_processors) -8 --memory=${XZ_MEM}"
5852ad2d 872
dc7d6b20
MT
873if [ -n "${BUILD_ARCH}" ]; then
874 configure_build "${BUILD_ARCH}"
949544f5 875else
dc7d6b20 876 configure_build "default"
949544f5
MT
877fi
878
df5e82b3 879buildtoolchain() {
69a6ec55
MT
880 local error=false
881 case "${BUILD_ARCH}:${HOST_ARCH}" in
882 # x86_64
883 x86_64:x86_64)
884 # This is working.
885 ;;
886
887 # x86
888 i586:i586|i586:i686|i586:x86_64)
889 # These are working.
890 ;;
891 i586:*)
892 error=true
893 ;;
894
895 # ARM
896 arvm7hl:armv7hl|armv7hl:armv7l)
897 # These are working.
898 ;;
899
900 armv5tel:armv5tel|armv5tel:armv5tejl|armv5tel:armv6l|armv5tel:armv7l|armv5tel:aarch64)
901 # These are working.
902 ;;
903 armv5tel:*)
904 error=true
905 ;;
906 esac
907
908 ${error} && \
909 exiterror "Cannot build ${BUILD_ARCH} toolchain on $(uname -m). Please use the download if any."
910
911 local gcc=$(type -p gcc)
912 if [ -z "${gcc}" ]; then
913 exiterror "Could not find GCC. You will need a working build enviroment in order to build the toolchain."
914 fi
915
6bd3a131
MT
916 # Check ${TOOLS_DIR} symlink
917 if [ -h "${TOOLS_DIR}" ]; then
918 rm -f "${TOOLS_DIR}"
919 fi
920
921 if [ ! -e "${TOOLS_DIR}" ]; then
922 ln -s "${BASEDIR}/build${TOOLS_DIR}" "${TOOLS_DIR}"
923 fi
924
925 if [ ! -h "${TOOLS_DIR}" ]; then
926 exiterror "Could not create ${TOOLS_DIR} symbolic link"
927 fi
928
69a6ec55
MT
929 LOGFILE="$BASEDIR/log/_build.toolchain.log"
930 export LOGFILE
931
932 lfsmake1 stage1
933 lfsmake1 ccache PASS=1
934 lfsmake1 binutils PASS=1
935 lfsmake1 gcc PASS=1
936 lfsmake1 linux KCFG="-headers"
937 lfsmake1 glibc
938 lfsmake1 gcc PASS=L
939 lfsmake1 binutils PASS=2
940 lfsmake1 gcc PASS=2
54d54148 941 lfsmake1 zlib
69a6ec55
MT
942 lfsmake1 ccache PASS=2
943 lfsmake1 tcl
944 lfsmake1 expect
945 lfsmake1 dejagnu
946 lfsmake1 pkg-config
947 lfsmake1 ncurses
948 lfsmake1 bash
949 lfsmake1 bzip2
950 lfsmake1 automake
951 lfsmake1 coreutils
952 lfsmake1 diffutils
953 lfsmake1 findutils
954 lfsmake1 gawk
955 lfsmake1 gettext
956 lfsmake1 grep
957 lfsmake1 gzip
958 lfsmake1 m4
959 lfsmake1 make
960 lfsmake1 patch
961 lfsmake1 perl
962 lfsmake1 sed
963 lfsmake1 tar
964 lfsmake1 texinfo
965 lfsmake1 xz
85439ac7 966 lfsmake1 bison
11b5e5cb 967 lfsmake1 flex
69a6ec55 968 lfsmake1 fake-environ
7b93b62b 969 lfsmake1 strip
69a6ec55 970 lfsmake1 cleanup-toolchain
df5e82b3
MT
971}
972
973buildbase() {
69a6ec55
MT
974 LOGFILE="$BASEDIR/log/_build.base.log"
975 export LOGFILE
976 lfsmake2 stage2
977 lfsmake2 linux KCFG="-headers"
978 lfsmake2 man-pages
979 lfsmake2 glibc
980 lfsmake2 tzdata
981 lfsmake2 cleanup-toolchain
982 lfsmake2 zlib
983 lfsmake2 binutils
984 lfsmake2 gmp
985 lfsmake2 gmp-compat
986 lfsmake2 mpfr
987 lfsmake2 libmpc
988 lfsmake2 file
989 lfsmake2 gcc
990 lfsmake2 sed
991 lfsmake2 autoconf
992 lfsmake2 automake
993 lfsmake2 berkeley
994 lfsmake2 coreutils
995 lfsmake2 iana-etc
996 lfsmake2 m4
997 lfsmake2 bison
69a6ec55
MT
998 lfsmake2 ncurses
999 lfsmake2 procps
1000 lfsmake2 libtool
1001 lfsmake2 perl
1002 lfsmake2 readline
1003 lfsmake2 readline-compat
1004 lfsmake2 bzip2
1005 lfsmake2 pcre
1006 lfsmake2 pcre-compat
1007 lfsmake2 bash
1008 lfsmake2 diffutils
1009 lfsmake2 e2fsprogs
1010 lfsmake2 ed
1011 lfsmake2 findutils
1012 lfsmake2 flex
1013 lfsmake2 gawk
1014 lfsmake2 gettext
1015 lfsmake2 grep
1016 lfsmake2 groff
1017 lfsmake2 gperf
1018 lfsmake2 gzip
1019 lfsmake2 hostname
1020 lfsmake2 iproute2
1021 lfsmake2 jwhois
1022 lfsmake2 kbd
1023 lfsmake2 less
4720fa0d 1024 lfsmake2 pkg-config
69a6ec55
MT
1025 lfsmake2 make
1026 lfsmake2 man
1027 lfsmake2 kmod
1028 lfsmake2 net-tools
1029 lfsmake2 patch
1030 lfsmake2 psmisc
1031 lfsmake2 shadow
1032 lfsmake2 sysklogd
1033 lfsmake2 sysvinit
1034 lfsmake2 tar
1035 lfsmake2 texinfo
1036 lfsmake2 util-linux
1037 lfsmake2 udev
1038 lfsmake2 vim
1039 lfsmake2 xz
1040 lfsmake2 paxctl
df5e82b3
MT
1041}
1042
15679d9f 1043buildipfire() {
907cd036 1044 LOGFILE="$BASEDIR/log/_build.ipfire.log"
df5e82b3 1045 export LOGFILE
489145db
MT
1046 lfsmake2 configroot
1047 lfsmake2 initscripts
1048 lfsmake2 backup
489145db
MT
1049 lfsmake2 libusb
1050 lfsmake2 libusb-compat
1051 lfsmake2 libpcap
1052 lfsmake2 ppp
1053 lfsmake2 pptp
1054 lfsmake2 unzip
1055 lfsmake2 which
1056 lfsmake2 linux-firmware
489145db 1057 lfsmake2 dvb-firmwares
37b86fa9 1058 lfsmake2 xr819-firmware
489145db
MT
1059 lfsmake2 zd1211-firmware
1060 lfsmake2 rpi-firmware
1061 lfsmake2 bc
2a0947f2 1062 lfsmake2 u-boot MKIMAGE=1
489145db
MT
1063 lfsmake2 cpio
1064 lfsmake2 mdadm
1065 lfsmake2 dracut
1066 lfsmake2 lvm2
1067 lfsmake2 multipath-tools
1068 lfsmake2 freetype
1069 lfsmake2 grub
1070 lfsmake2 libmnl
1071 lfsmake2 libnfnetlink
1072 lfsmake2 libnetfilter_queue
1073 lfsmake2 libnetfilter_conntrack
1074 lfsmake2 libnetfilter_cthelper
1075 lfsmake2 libnetfilter_cttimeout
1076 lfsmake2 iptables
0245f3b6 1077 lfsmake2 screen
54ead8ef 1078 lfsmake2 elfutils
8e6fb99d 1079
dc7d6b20 1080 case "${BUILD_ARCH}" in
fc155193 1081 x86_64)
489145db 1082 lfsmake2 linux KCFG=""
b389d731
AF
1083# lfsmake2 backports KCFG=""
1084# lfsmake2 e1000e KCFG=""
1085# lfsmake2 igb KCFG=""
1086# lfsmake2 ixgbe KCFG=""
489145db
MT
1087 lfsmake2 xtables-addons KCFG=""
1088 lfsmake2 linux-initrd KCFG=""
fc155193 1089 ;;
3d02c091
MT
1090 i586)
1091 # x86-pae (Native and new XEN) kernel build
489145db 1092 lfsmake2 linux KCFG="-pae"
b389d731
AF
1093# lfsmake2 backports KCFG="-pae"
1094# lfsmake2 e1000e KCFG="-pae"
1095# lfsmake2 igb KCFG="-pae"
1096# lfsmake2 ixgbe KCFG="-pae"
489145db
MT
1097 lfsmake2 xtables-addons KCFG="-pae"
1098 lfsmake2 linux-initrd KCFG="-pae"
3d02c091
MT
1099
1100 # x86 kernel build
489145db 1101 lfsmake2 linux KCFG=""
b389d731
AF
1102# lfsmake2 backports KCFG=""
1103# lfsmake2 e1000e KCFG=""
1104# lfsmake2 igb KCFG=""
1105# lfsmake2 ixgbe KCFG=""
489145db
MT
1106 lfsmake2 xtables-addons KCFG=""
1107 lfsmake2 linux-initrd KCFG=""
3d02c091 1108 ;;
544f40d4 1109
3d02c091 1110 armv5tel)
3d02c091 1111 # arm-kirkwood (Dreamplug, ICY-Box ...) kernel build
489145db 1112 lfsmake2 linux KCFG="-kirkwood"
0a21d63f
AF
1113# lfsmake2 backports KCFG="-kirkwood"
1114# lfsmake2 e1000e KCFG="-kirkwood"
1115# lfsmake2 igb KCFG="-kirkwood"
1116# lfsmake2 ixgbe KCFG="-kirkwood"
489145db
MT
1117 lfsmake2 xtables-addons KCFG="-kirkwood"
1118 lfsmake2 linux-initrd KCFG="-kirkwood"
3d02c091
MT
1119
1120 # arm multi platform (Panda, Wandboard ...) kernel build
489145db 1121 lfsmake2 linux KCFG="-multi"
0a21d63f
AF
1122# lfsmake2 backports KCFG="-multi"
1123# lfsmake2 e1000e KCFG="-multi"
1124# lfsmake2 igb KCFG="-multi"
1125# lfsmake2 ixgbe KCFG="-multi"
489145db
MT
1126 lfsmake2 xtables-addons KCFG="-multi"
1127 lfsmake2 linux-initrd KCFG="-multi"
3d02c091
MT
1128 ;;
1129 esac
489145db
MT
1130 lfsmake2 xtables-addons USPACE="1"
1131 lfsmake2 openssl
1132 [ "${BUILD_ARCH}" = "i586" ] && lfsmake2 openssl KCFG='-sse2'
11e78f38 1133 lfsmake2 openssl-compat
489145db
MT
1134 lfsmake2 libgpg-error
1135 lfsmake2 libgcrypt
1136 lfsmake2 libassuan
1137 lfsmake2 nettle
1138 lfsmake2 libevent
1139 lfsmake2 libevent2
1140 lfsmake2 expat
c8e9a7a8
WA
1141 lfsmake2 apr
1142 lfsmake2 aprutil
489145db
MT
1143 lfsmake2 unbound
1144 lfsmake2 gnutls
1145 lfsmake2 bind
1146 lfsmake2 dhcp
1147 lfsmake2 dhcpcd
1148 lfsmake2 boost
1149 lfsmake2 linux-atm
1150 lfsmake2 gdbm
1151 lfsmake2 pam
1152 lfsmake2 curl
1153 lfsmake2 tcl
1154 lfsmake2 sqlite
1155 lfsmake2 libffi
1156 lfsmake2 python
1157 lfsmake2 python3
1158 lfsmake2 ca-certificates
1159 lfsmake2 fireinfo
1160 lfsmake2 libnet
1161 lfsmake2 libnl
1162 lfsmake2 libnl-3
1163 lfsmake2 libidn
1164 lfsmake2 nasm
1165 lfsmake2 libjpeg
1166 lfsmake2 libjpeg-compat
1167 lfsmake2 libexif
1168 lfsmake2 libpng
1169 lfsmake2 libtiff
1170 lfsmake2 libart
1171 lfsmake2 gd
1172 lfsmake2 popt
489145db
MT
1173 lfsmake2 slang
1174 lfsmake2 newt
1175 lfsmake2 libsmooth
1176 lfsmake2 attr
1177 lfsmake2 acl
1178 lfsmake2 libcap
1179 lfsmake2 pciutils
1180 lfsmake2 usbutils
1181 lfsmake2 libxml2
1182 lfsmake2 libxslt
1183 lfsmake2 BerkeleyDB
489145db
MT
1184 lfsmake2 cyrus-sasl
1185 lfsmake2 openldap
1186 lfsmake2 apache2
489145db
MT
1187 lfsmake2 web-user-interface
1188 lfsmake2 flag-icons
1189 lfsmake2 jquery
6033b271 1190 lfsmake2 bootstrap
489145db
MT
1191 lfsmake2 arping
1192 lfsmake2 beep
1193 lfsmake2 dvdrtools
1194 lfsmake2 dosfstools
1195 lfsmake2 reiserfsprogs
1196 lfsmake2 xfsprogs
1197 lfsmake2 sysfsutils
1198 lfsmake2 fuse
1199 lfsmake2 ntfs-3g
1200 lfsmake2 ethtool
1201 lfsmake2 ez-ipupdate
1202 lfsmake2 fcron
1203 lfsmake2 perl-GD
1204 lfsmake2 GD-Graph
1205 lfsmake2 GD-TextUtil
1206 lfsmake2 perl-Device-SerialPort
1207 lfsmake2 perl-Device-Modem
1208 lfsmake2 perl-Apache-Htpasswd
1209 lfsmake2 gnupg
1210 lfsmake2 hdparm
1211 lfsmake2 sdparm
1212 lfsmake2 mtools
1213 lfsmake2 whatmask
1214 lfsmake2 conntrack-tools
1215 lfsmake2 libupnp
1216 lfsmake2 ipaddr
1217 lfsmake2 iputils
1218 lfsmake2 l7-protocols
489145db
MT
1219 lfsmake2 hwdata
1220 lfsmake2 logrotate
1221 lfsmake2 logwatch
1222 lfsmake2 misc-progs
1223 lfsmake2 nano
1224 lfsmake2 URI
1225 lfsmake2 HTML-Tagset
1226 lfsmake2 HTML-Parser
1227 lfsmake2 HTML-Template
1228 lfsmake2 Compress-Zlib
1229 lfsmake2 Digest
1230 lfsmake2 Digest-SHA1
1231 lfsmake2 Digest-HMAC
1232 lfsmake2 libwww-perl
1233 lfsmake2 Net-DNS
1234 lfsmake2 Net-IPv4Addr
1235 lfsmake2 Net_SSLeay
1236 lfsmake2 IO-Stringy
1237 lfsmake2 IO-Socket-SSL
1238 lfsmake2 Unix-Syslog
1239 lfsmake2 Mail-Tools
1240 lfsmake2 MIME-Tools
1241 lfsmake2 Net-Server
1242 lfsmake2 Convert-TNEF
1243 lfsmake2 Convert-UUlib
1244 lfsmake2 Archive-Tar
1245 lfsmake2 Archive-Zip
1246 lfsmake2 Text-Tabs+Wrap
1247 lfsmake2 Locale-Country
1248 lfsmake2 XML-Parser
1249 lfsmake2 Crypt-PasswdMD5
1250 lfsmake2 Net-Telnet
1251 lfsmake2 python-setuptools
1252 lfsmake2 python-clientform
1253 lfsmake2 python-mechanize
1254 lfsmake2 python-feedparser
1255 lfsmake2 python-rssdler
1256 lfsmake2 python-inotify
1257 lfsmake2 python-docutils
1258 lfsmake2 python-daemon
1259 lfsmake2 python-ipaddress
1260 lfsmake2 glib
1261 lfsmake2 GeoIP
489145db
MT
1262 lfsmake2 ntp
1263 lfsmake2 openssh
1264 lfsmake2 fontconfig
1265 lfsmake2 dejavu-fonts-ttf
70f6cba4 1266 lfsmake2 ubuntu-font-family
489145db
MT
1267 lfsmake2 freefont
1268 lfsmake2 pixman
1269 lfsmake2 cairo
1270 lfsmake2 pango
1271 lfsmake2 rrdtool
1272 lfsmake2 setserial
1273 lfsmake2 setup
1274 lfsmake2 libdnet
1275 lfsmake2 daq
1276 lfsmake2 snort
1277 lfsmake2 oinkmaster
1278 lfsmake2 squid
1279 lfsmake2 squidguard
1280 lfsmake2 calamaris
1281 lfsmake2 tcpdump
1282 lfsmake2 traceroute
1283 lfsmake2 vlan
1284 lfsmake2 wireless
1285 lfsmake2 pakfire
1286 lfsmake2 spandsp
adf3f4f4 1287 lfsmake2 lz4
489145db
MT
1288 lfsmake2 lzo
1289 lfsmake2 openvpn
489145db
MT
1290 lfsmake2 mpage
1291 lfsmake2 dbus
1292 lfsmake2 intltool
1293 lfsmake2 libdaemon
1294 lfsmake2 cups
489145db 1295 lfsmake2 lcms2
56170c2a 1296 lfsmake2 ghostscript
489145db
MT
1297 lfsmake2 qpdf
1298 lfsmake2 poppler
1299 lfsmake2 cups-filters
1300 lfsmake2 epson-inkjet-printer-escpr
1301 lfsmake2 foomatic
1302 lfsmake2 hplip
1303 lfsmake2 cifs-utils
1304 lfsmake2 krb5
1305 lfsmake2 samba
1306 lfsmake2 sudo
1307 lfsmake2 mc
1308 lfsmake2 wget
1309 lfsmake2 bridge-utils
0245f3b6 1310# lfsmake2 screen
489145db
MT
1311 lfsmake2 smartmontools
1312 lfsmake2 htop
1313 lfsmake2 chkconfig
1314 lfsmake2 postfix
1315 lfsmake2 fetchmail
1316 lfsmake2 cyrus-imapd
489145db
MT
1317 lfsmake2 clamav
1318 lfsmake2 spamassassin
1319 lfsmake2 amavisd
1320 lfsmake2 dma
1321 lfsmake2 alsa
1322 lfsmake2 mpfire
1323 lfsmake2 guardian
1324 lfsmake2 libid3tag
1325 lfsmake2 libmad
1326 lfsmake2 libogg
1327 lfsmake2 libvorbis
1328 lfsmake2 libdvbpsi
1329 lfsmake2 flac
1330 lfsmake2 lame
1331 lfsmake2 sox
1332 lfsmake2 libshout
1333 lfsmake2 xvid
1334 lfsmake2 libmpeg2
1335 lfsmake2 libarchive
1336 lfsmake2 cmake
1337 lfsmake2 gnump3d
1338 lfsmake2 rsync
489145db
MT
1339 lfsmake2 libtirpc
1340 lfsmake2 rpcbind
1341 lfsmake2 nfs
1342 lfsmake2 gnu-netcat
1343 lfsmake2 ncat
1344 lfsmake2 nmap
489145db
MT
1345 lfsmake2 etherwake
1346 lfsmake2 bwm-ng
1347 lfsmake2 sysstat
489145db
MT
1348 lfsmake2 strongswan
1349 lfsmake2 rng-tools
1350 lfsmake2 lsof
1351 lfsmake2 br2684ctl
1352 lfsmake2 pcmciautils
1353 lfsmake2 lm_sensors
1354 lfsmake2 liboping
1355 lfsmake2 collectd
1356 lfsmake2 elinks
1357 lfsmake2 igmpproxy
1358 lfsmake2 fbset
1359 lfsmake2 opus
1360 lfsmake2 python-six
1361 lfsmake2 python-pyparsing
1362 lfsmake2 spice-protocol
1363 lfsmake2 spice
1364 lfsmake2 sdl
1365 lfsmake2 libusbredir
1366 lfsmake2 qemu
1367 lfsmake2 sane
1368 lfsmake2 netpbm
489145db 1369 lfsmake2 netsnmpd
489145db 1370 lfsmake2 nagios_nrpe
2af354c2 1371 lfsmake2 nagios-plugins
489145db
MT
1372 lfsmake2 icinga
1373 lfsmake2 ebtables
1374 lfsmake2 directfb
489145db
MT
1375 lfsmake2 faad2
1376 lfsmake2 ffmpeg
1377 lfsmake2 vdr
1378 lfsmake2 vdr_streamdev
489145db
MT
1379 lfsmake2 vdr_epgsearch
1380 lfsmake2 vdr_dvbapi
1381 lfsmake2 vdr_eepg
1382 lfsmake2 w_scan
1383 lfsmake2 icecast
1384 lfsmake2 icegenerator
1385 lfsmake2 mpd
1386 lfsmake2 libmpdclient
1387 lfsmake2 mpc
1388 lfsmake2 perl-Net-SMTP-SSL
1389 lfsmake2 perl-MIME-Base64
1390 lfsmake2 perl-Authen-SASL
1391 lfsmake2 perl-MIME-Lite
1392 lfsmake2 perl-Email-Date-Format
1393 lfsmake2 git
1394 lfsmake2 squidclamav
1395 lfsmake2 vnstat
1396 lfsmake2 iw
1397 lfsmake2 wpa_supplicant
1398 lfsmake2 hostapd
1399 lfsmake2 pycurl
1400 lfsmake2 urlgrabber
1401 lfsmake2 syslinux
1402 lfsmake2 tftpd
1403 lfsmake2 cpufrequtils
1404 lfsmake2 bluetooth
1405 lfsmake2 gutenprint
1406 lfsmake2 apcupsd
1407 lfsmake2 iperf
1408 lfsmake2 iperf3
1409 lfsmake2 7zip
1410 lfsmake2 lynis
1411 lfsmake2 streamripper
1412 lfsmake2 sshfs
1413 lfsmake2 taglib
489145db
MT
1414 lfsmake2 sslh
1415 lfsmake2 perl-gettext
1416 lfsmake2 perl-Sort-Naturally
1417 lfsmake2 vdradmin
1418 lfsmake2 miau
1419 lfsmake2 perl-DBI
489145db
MT
1420 lfsmake2 perl-DBD-SQLite
1421 lfsmake2 perl-File-ReadBackwards
489145db 1422 lfsmake2 openvmtools
489145db
MT
1423 lfsmake2 motion
1424 lfsmake2 joe
1425 lfsmake2 monit
1426 lfsmake2 nut
1427 lfsmake2 watchdog
1428 lfsmake2 libpri
1429 lfsmake2 libsrtp
b713ec03 1430 lfsmake2 jansson
489145db 1431 lfsmake2 asterisk
489145db
MT
1432 lfsmake2 usb_modeswitch
1433 lfsmake2 usb_modeswitch_data
1434 lfsmake2 zerofree
489145db
MT
1435 lfsmake2 minicom
1436 lfsmake2 ddrescue
489145db
MT
1437 lfsmake2 miniupnpd
1438 lfsmake2 client175
1439 lfsmake2 powertop
1440 lfsmake2 parted
1441 lfsmake2 swig
2a0947f2 1442 lfsmake2 u-boot
bf1e7598 1443 lfsmake2 u-boot-kirkwood
5c82a9f0 1444 lfsmake2 python-typing
489145db
MT
1445 lfsmake2 python-m2crypto
1446 lfsmake2 wireless-regdb
1447 lfsmake2 crda
1448 lfsmake2 libsolv
1449 lfsmake2 python-distutils-extra
1450 lfsmake2 python-lzma
1451 lfsmake2 python-progressbar
1452 lfsmake2 python-xattr
1453 lfsmake2 ddns
1454 lfsmake2 transmission
1455 lfsmake2 dpfhack
1456 lfsmake2 lcd4linux
1457 lfsmake2 mtr
489145db
MT
1458 lfsmake2 minidlna
1459 lfsmake2 acpid
1460 lfsmake2 fping
1461 lfsmake2 telnet
1462 lfsmake2 xinetd
1463 lfsmake2 gpgme
1464 lfsmake2 pygpgme
1465 lfsmake2 pakfire3
1466 lfsmake2 stress
1467 lfsmake2 libstatgrab
1468 lfsmake2 sarg
1469 lfsmake2 check_mk_agent
1470 lfsmake2 nginx
1471 lfsmake2 sendEmail
1472 lfsmake2 sysbench
1473 lfsmake2 strace
489145db
MT
1474 lfsmake2 ltrace
1475 lfsmake2 ipfire-netboot
1476 lfsmake2 lcdproc
1477 lfsmake2 bitstream
1478 lfsmake2 multicat
1479 lfsmake2 keepalived
1480 lfsmake2 ipvsadm
1481 lfsmake2 perl-Carp-Clan
1482 lfsmake2 perl-Date-Calc
1483 lfsmake2 perl-Date-Manip
1484 lfsmake2 perl-File-Tail
1485 lfsmake2 perl-TimeDate
1486 lfsmake2 swatch
1487 lfsmake2 tor
1488 lfsmake2 arm
1489 lfsmake2 wavemon
1490 lfsmake2 iptraf-ng
1491 lfsmake2 iotop
1492 lfsmake2 stunnel
489145db
MT
1493 lfsmake2 bacula
1494 lfsmake2 batctl
b62c826f
MT
1495 lfsmake2 perl-Font-TTF
1496 lfsmake2 perl-IO-String
489145db
MT
1497 lfsmake2 perl-PDF-API2
1498 lfsmake2 squid-accounting
1499 lfsmake2 pigz
1500 lfsmake2 tmux
1501 lfsmake2 perl-Text-CSV_XS
489145db
MT
1502 lfsmake2 haproxy
1503 lfsmake2 ipset
1504 lfsmake2 lua
1505 lfsmake2 dnsdist
1506 lfsmake2 bird
1507 lfsmake2 dmidecode
1508 lfsmake2 mcelog
1509 lfsmake2 rtpproxy
1510 lfsmake2 util-macros
1511 lfsmake2 libpciaccess
1512 lfsmake2 libyajl
1513 lfsmake2 libvirt
1514 lfsmake2 freeradius
1515 lfsmake2 perl-common-sense
1516 lfsmake2 perl-inotify2
1517 lfsmake2 perl-Net-IP
0d6cc79d 1518 lfsmake2 wio
773caa66 1519 lfsmake2 iftop
ddcd60f7 1520 lfsmake2 mdns-repeater
429af178 1521 lfsmake2 i2c-tools
d0817963 1522}
df5e82b3
MT
1523
1524buildinstaller() {
1525 # Run installer scripts one by one
1526 LOGFILE="$BASEDIR/log/_build.installer.log"
1527 export LOGFILE
489145db
MT
1528 lfsmake2 memtest
1529 lfsmake2 installer
ce9264a1
AF
1530 # use toolchain bash for chroot to strip
1531 EXTRA_PATH=${TOOLS_DIR}/bin/ lfsmake2 strip
df5e82b3
MT
1532}
1533
1534buildpackages() {
1535 LOGFILE="$BASEDIR/log/_build.packages.log"
1536 export LOGFILE
1537 echo "... see detailed log in _build.*.log files" >> $LOGFILE
0fbb45e9 1538
df5e82b3
MT
1539
1540 # Generating list of packages used
dc4ae0b7 1541 print_line "Generating packages list from logs"
df5e82b3
MT
1542 rm -f $BASEDIR/doc/packages-list
1543 for i in `ls -1tr $BASEDIR/log/[^_]*`; do
1544 if [ "$i" != "$BASEDIR/log/FILES" -a -n $i ]; then
7471f6ab 1545 echo "* `basename $i`" >>$BASEDIR/doc/packages-list
df5e82b3
MT
1546 fi
1547 done
7471f6ab 1548 echo "== List of softwares used to build $NAME Version: $VERSION ==" > $BASEDIR/doc/packages-list.txt
4fe9acb2 1549 grep -v 'configroot$\|img$\|initrd$\|initscripts$\|installer$\|install$\|setup$\|pakfire$\|stage2$\|smp$\|tools$\|tools1$\|tools2$\|.tgz$\|-config$\|_missing_rootfile$\|install1$\|install2$\|pass1$\|pass2$\|pass3$' \
df5e82b3
MT
1550 $BASEDIR/doc/packages-list | sort >> $BASEDIR/doc/packages-list.txt
1551 rm -f $BASEDIR/doc/packages-list
c9673262 1552 # packages-list.txt is ready to be displayed for wiki page
f9783277 1553 print_status DONE
4b06f504
MT
1554
1555 # Update changelog
e49f7f0d 1556 cd $BASEDIR
c43b07fd
AF
1557 [ -z $GIT_TAG ] || LAST_TAG=$GIT_TAG
1558 [ -z $LAST_TAG ] || EXT="$LAST_TAG..HEAD"
1559 git log -n 500 --no-merges --pretty=medium --shortstat $EXT > $BASEDIR/doc/ChangeLog
df5e82b3 1560
9607771a 1561 # Create images for install
489145db 1562 lfsmake2 cdrom
bada0832 1563
4dc82852 1564 # Check if there is a loop device for building in virtual environments
841663e7
MT
1565 modprobe loop 2>/dev/null
1566 if [ $BUILD_IMAGES == 1 ] && ([ -e /dev/loop/0 ] || [ -e /dev/loop0 ] || [ -e "/dev/loop-control" ]); then
489145db 1567 lfsmake2 flash-images
4dc82852 1568 fi
c9673262 1569
b302b9a6 1570 mv $LFS/install/images/{*.iso,*.tgz,*.img.xz,*.bz2} $BASEDIR >> $LOGFILE 2>&1
c9673262 1571
0d909a4a 1572 ipfirepackages
e67a57fe 1573
489145db 1574 lfsmake2 xen-image
939c2a21 1575 mv $LFS/install/images/*.bz2 $BASEDIR >> $LOGFILE 2>&1
bada0832 1576
b307417f 1577 cd $BASEDIR
744a04ea
AF
1578
1579 # remove not useable iso on armv5tel (needed to build flash images)
dc7d6b20 1580 [ "${BUILD_ARCH}" = "armv5tel" ] && rm -rf *.iso
744a04ea 1581
b307417f
AF
1582 for i in `ls *.bz2 *.img.gz *.iso`; do
1583 md5sum $i > $i.md5
1584 done
1585 cd $PWD
1586
e67a57fe
MT
1587 # Cleanup
1588 stdumount
1589 rm -rf $BASEDIR/build/tmp/*
1590
e67a57fe 1591 cd $PWD
e67a57fe
MT
1592}
1593
1594ipfirepackages() {
489145db 1595 lfsmake2 core-updates
5596077b
MT
1596
1597 local i
dc7d6b20 1598 for i in $(find $BASEDIR/config/rootfiles/packages{/${BUILD_ARCH},} -maxdepth 1 -type f); do
5596077b 1599 i=$(basename ${i})
453b418b
MT
1600 if [ -e $BASEDIR/lfs/$i ]; then
1601 ipfiredist $i
1602 else
1603 echo -n $i
f9783277 1604 print_status SKIP
453b418b 1605 fi
fe7fe395 1606 done
78331e30 1607 test -d $BASEDIR/packages || mkdir $BASEDIR/packages
5c8cfc99 1608 mv -f $LFS/install/packages/* $BASEDIR/packages >> $LOGFILE 2>&1
483f59cd 1609 rm -rf $BASEDIR/build/install/packages/*
df5e82b3
MT
1610}
1611
bcb9dc13
MT
1612while [ $# -gt 0 ]; do
1613 case "${1}" in
1614 --target=*)
c2e810de 1615 configure_build "${1#--target=}"
bcb9dc13
MT
1616 ;;
1617 -*)
1618 exiterror "Unknown configuration option: ${1}"
1619 ;;
1620 *)
1621 # Found a command, so exit options parsing.
1622 break
1623 ;;
1624 esac
1625 shift
1626done
1627
df5e82b3
MT
1628# See what we're supposed to do
1629case "$1" in
1630build)
f9783277
MT
1631 START_TIME=$(now)
1632
1633 # Clear screen
1634 ${INTERACTIVE} && clear
1635
f74072a2 1636 PACKAGE=`ls -v -r $BASEDIR/cache/toolchains/$SNAME-$VERSION-toolchain-$TOOLCHAINVER-${BUILD_ARCH}.tar.xz 2> /dev/null | head -n 1`
df5e82b3 1637 #only restore on a clean disk
6c4cc7ea 1638 if [ ! -e "${BASEDIR}/build${TOOLS_DIR}/.toolchain-successful" ]; then
df5e82b3 1639 if [ ! -n "$PACKAGE" ]; then
f9783277 1640 print_build_stage "Full toolchain compilation"
df5e82b3
MT
1641 prepareenv
1642 buildtoolchain
1643 else
f74072a2 1644 PACKAGENAME=${PACKAGE%.tar.xz}
f9783277 1645 print_build_stage "Packaged toolchain compilation"
df5e82b3 1646 if [ `md5sum $PACKAGE | awk '{print $1}'` == `cat $PACKAGENAME.md5 | awk '{print $1}'` ]; then
f74072a2 1647 tar axf $PACKAGE
df5e82b3
MT
1648 prepareenv
1649 else
1650 exiterror "$PACKAGENAME md5 did not match, check downloaded package"
1651 fi
1652 fi
1653 else
df5e82b3
MT
1654 prepareenv
1655 fi
5cfe86e6 1656
f9783277 1657 print_build_stage "Building LFS"
df5e82b3 1658 buildbase
15679d9f 1659
f9783277 1660 print_build_stage "Building IPFire"
15679d9f 1661 buildipfire
5cfe86e6 1662
f9783277 1663 print_build_stage "Building installer"
df5e82b3 1664 buildinstaller
15679d9f 1665
f9783277 1666 print_build_stage "Building packages"
df5e82b3 1667 buildpackages
7a5ed24e 1668
f9783277 1669 print_build_stage "Checking Logfiles for new Files"
b307417f
AF
1670
1671 cd $BASEDIR
7a5ed24e 1672 tools/checknewlog.pl
e0c923f4 1673 tools/checkrootfiles
b307417f 1674 cd $PWD
a23731d1 1675
f9783277 1676 print_build_summary $(( $(now) - ${START_TIME} ))
df5e82b3
MT
1677 ;;
1678shell)
1679 # enter a shell inside LFS chroot
1680 # may be used to changed kernel settings
1681 prepareenv
1682 entershell
1683 ;;
df5e82b3 1684clean)
f9783277
MT
1685 print_line "Cleaning build directory..."
1686
df5e82b3
MT
1687 for i in `mount | grep $BASEDIR | sed 's/^.*loop=\(.*\))/\1/'`; do
1688 $LOSETUP -d $i 2>/dev/null
1689 done
1690 for i in `mount | grep $BASEDIR | cut -d " " -f 1`; do
1691 umount $i
1692 done
1693 stdumount
1694 for i in `seq 0 7`; do
69a6ec55 1695 if ( losetup /dev/loop${i} 2>/dev/null | grep -q "/install/images" ); then
df5e82b3
MT
1696 umount /dev/loop${i} 2>/dev/null;
1697 losetup -d /dev/loop${i} 2>/dev/null;
69a6ec55 1698 fi;
df5e82b3
MT
1699 done
1700 rm -rf $BASEDIR/build
1701 rm -rf $BASEDIR/cdrom
f9315063 1702 rm -rf $BASEDIR/packages
df5e82b3 1703 rm -rf $BASEDIR/log
6c4cc7ea
MT
1704 if [ -h "${TOOLS_DIR}" ]; then
1705 rm -f "${TOOLS_DIR}"
df5e82b3 1706 fi
b307417f 1707 rm -f $BASEDIR/ipfire-*
f9783277 1708 print_status DONE
df5e82b3 1709 ;;
c3db995c 1710downloadsrc)
df5e82b3
MT
1711 if [ ! -d $BASEDIR/cache ]; then
1712 mkdir $BASEDIR/cache
1713 fi
1714 mkdir -p $BASEDIR/log
857d9bf2 1715 echo -e "${BOLD}Preload all source files${NORMAL}" | tee -a $LOGFILE
df5e82b3
MT
1716 FINISHED=0
1717 cd $BASEDIR/lfs
1718 for c in `seq $MAX_RETRIES`; do
1719 if (( FINISHED==1 )); then
1720 break
1721 fi
1722 FINISHED=1
1723 cd $BASEDIR/lfs
1724 for i in *; do
1725 if [ -f "$i" -a "$i" != "Config" ]; then
846e756e
MT
1726 lfsmakecommoncheck ${i} || continue
1727
dc7d6b20 1728 make -s -f $i LFS_BASEDIR=$BASEDIR BUILD_ARCH="${BUILD_ARCH}" \
51f9e7ac 1729 MESSAGE="$i\t ($c/$MAX_RETRIES)" download >> $LOGFILE 2>&1
df5e82b3 1730 if [ $? -ne 0 ]; then
f9783277 1731 print_status FAIL
df5e82b3
MT
1732 FINISHED=0
1733 else
1734 if [ $c -eq 1 ]; then
f9783277 1735 print_status DONE
df5e82b3
MT
1736 fi
1737 fi
1738 fi
1739 done
1740 done
e22c7973 1741 echo -e "${BOLD}***Verifying md5sums${NORMAL}"
df5e82b3
MT
1742 ERROR=0
1743 for i in *; do
1744 if [ -f "$i" -a "$i" != "Config" ]; then
a4130265 1745 lfsmakecommoncheck ${i} > /dev/null || continue
dc7d6b20 1746 make -s -f $i LFS_BASEDIR=$BASEDIR BUILD_ARCH="${BUILD_ARCH}" \
51f9e7ac 1747 MESSAGE="$i\t " md5 >> $LOGFILE 2>&1
df5e82b3 1748 if [ $? -ne 0 ]; then
e22c7973 1749 echo -ne "MD5 difference in lfs/$i"
f9783277 1750 print_status FAIL
df5e82b3
MT
1751 ERROR=1
1752 fi
1753 fi
1754 done
1755 if [ $ERROR -eq 0 ]; then
e22c7973 1756 echo -ne "${BOLD}all files md5sum match${NORMAL}"
f9783277 1757 print_status DONE
e22c7973
MT
1758 else
1759 echo -ne "${BOLD}not all files were correctly download${NORMAL}"
f9783277 1760 print_status FAIL
df5e82b3 1761 fi
e22c7973 1762 cd - >/dev/null 2>&1
df5e82b3 1763 ;;
df5e82b3 1764toolchain)
f9783277
MT
1765 # Clear screen
1766 ${INTERACTIVE} && clear
1767
df5e82b3 1768 prepareenv
f3b7cf47 1769 print_build_stage "Toolchain compilation (${BUILD_ARCH})"
df5e82b3 1770 buildtoolchain
f74072a2 1771 echo "`date -u '+%b %e %T'`: Create toolchain image for ${BUILD_ARCH}" | tee -a $LOGFILE
11104bfe 1772 test -d $BASEDIR/cache/toolchains || mkdir -p $BASEDIR/cache/toolchains
27267889 1773 cd $BASEDIR && XZ_OPT="$(XZ_OPT)" tar -Jc --exclude='log/_build.*.log' -f cache/toolchains/$SNAME-$VERSION-toolchain-$TOOLCHAINVER-${BUILD_ARCH}.tar.xz --xz \
6c4cc7ea 1774 build/${TOOLS_DIR} build/bin/sh log >> $LOGFILE
f74072a2 1775 md5sum cache/toolchains/$SNAME-$VERSION-toolchain-$TOOLCHAINVER-${BUILD_ARCH}.tar.xz \
dc7d6b20 1776 > cache/toolchains/$SNAME-$VERSION-toolchain-$TOOLCHAINVER-${BUILD_ARCH}.md5
df5e82b3
MT
1777 stdumount
1778 ;;
1779gettoolchain)
df5e82b3 1780 # arbitrary name to be updated in case of new toolchain package upload
dc7d6b20 1781 PACKAGE=$SNAME-$VERSION-toolchain-$TOOLCHAINVER-${BUILD_ARCH}
f74072a2 1782 if [ ! -f $BASEDIR/cache/toolchains/$PACKAGE.tar.xz ]; then
5bd13f01 1783 URL_TOOLCHAIN=`grep URL_TOOLCHAIN lfs/Config | awk '{ print $3 }'`
11104bfe 1784 test -d $BASEDIR/cache/toolchains || mkdir -p $BASEDIR/cache/toolchains
f74072a2 1785 echo "`date -u '+%b %e %T'`: Load toolchain image for ${BUILD_ARCH}" | tee -a $LOGFILE
712d859c 1786 cd $BASEDIR/cache/toolchains
f74072a2 1787 wget -U "IPFireSourceGrabber/2.x" $URL_TOOLCHAIN/$PACKAGE.tar.xz $URL_TOOLCHAIN/$PACKAGE.md5 >& /dev/null
712d859c 1788 if [ $? -ne 0 ]; then
dc7d6b20 1789 echo "`date -u '+%b %e %T'`: error downloading $PACKAGE toolchain for ${BUILD_ARCH} machine" | tee -a $LOGFILE
40a4ea4c 1790 else
f74072a2 1791 if [ "`md5sum $PACKAGE.tar.xz | awk '{print $1}'`" = "`cat $PACKAGE.md5 | awk '{print $1}'`" ]; then
712d859c
MT
1792 echo "`date -u '+%b %e %T'`: toolchain md5 ok" | tee -a $LOGFILE
1793 else
1794 exiterror "$PACKAGE.md5 did not match, check downloaded package"
1795 fi
40a4ea4c 1796 fi
712d859c
MT
1797 else
1798 echo "Toolchain is already downloaded. Exiting..."
df5e82b3
MT
1799 fi
1800 ;;
15679d9f
MT
1801uploadsrc)
1802 PWD=`pwd`
661d9388
CS
1803 if [ -z $IPFIRE_USER ]; then
1804 echo -n "You have to setup IPFIRE_USER first. See .config for details."
f9783277 1805 print_status FAIL
661d9388
CS
1806 exit 1
1807 fi
ae23a606 1808
661d9388 1809 URL_SOURCE=$(grep URL_SOURCE lfs/Config | awk '{ print $3 }')
15e38431 1810 REMOTE_FILES=$(echo "ls -1" | sftp -C ${IPFIRE_USER}@${URL_SOURCE})
661d9388 1811
15e38431
MT
1812 for file in ${BASEDIR}/cache/*; do
1813 [ -d "${file}" ] && continue
1814 grep -q "$(basename ${file})" <<<$REMOTE_FILES && continue
661d9388 1815 NEW_FILES="$NEW_FILES $file"
0eab8e84 1816 done
661d9388
CS
1817 [ -n "$NEW_FILES" ] && scp -2 $NEW_FILES ${IPFIRE_USER}@${URL_SOURCE}
1818 cd $BASEDIR
15679d9f
MT
1819 cd $PWD
1820 exit 0
0eab8e84 1821 ;;
bf7c473f 1822lang)
69a6ec55
MT
1823 echo -ne "Checking the translations for missing or obsolete strings..."
1824 chmod 755 $BASEDIR/tools/{check_strings.pl,sort_strings.pl,check_langs.sh}
1825 $BASEDIR/tools/sort_strings.pl en
1826 $BASEDIR/tools/sort_strings.pl de
1827 $BASEDIR/tools/sort_strings.pl fr
1828 $BASEDIR/tools/sort_strings.pl es
1829 $BASEDIR/tools/sort_strings.pl pl
1830 $BASEDIR/tools/sort_strings.pl ru
1831 $BASEDIR/tools/sort_strings.pl nl
1832 $BASEDIR/tools/sort_strings.pl tr
1833 $BASEDIR/tools/sort_strings.pl it
1834 $BASEDIR/tools/check_strings.pl en > $BASEDIR/doc/language_issues.en
1835 $BASEDIR/tools/check_strings.pl de > $BASEDIR/doc/language_issues.de
1836 $BASEDIR/tools/check_strings.pl fr > $BASEDIR/doc/language_issues.fr
1837 $BASEDIR/tools/check_strings.pl es > $BASEDIR/doc/language_issues.es
1838 $BASEDIR/tools/check_strings.pl es > $BASEDIR/doc/language_issues.pl
1839 $BASEDIR/tools/check_strings.pl ru > $BASEDIR/doc/language_issues.ru
1840 $BASEDIR/tools/check_strings.pl nl > $BASEDIR/doc/language_issues.nl
1841 $BASEDIR/tools/check_strings.pl tr > $BASEDIR/doc/language_issues.tr
1842 $BASEDIR/tools/check_strings.pl it > $BASEDIR/doc/language_issues.it
1843 $BASEDIR/tools/check_langs.sh > $BASEDIR/doc/language_missings
f9783277 1844 print_status DONE
69a6ec55
MT
1845
1846 echo -ne "Updating language lists..."
1847 update_language_list ${BASEDIR}/src/installer/po
1848 update_language_list ${BASEDIR}/src/setup/po
f9783277 1849 print_status DONE
bf7c473f 1850 ;;
6b8cff41 1851*)
a50d04ab 1852 echo "Usage: $0 {build|changelog|clean|gettoolchain|downloadsrc|shell|sync|toolchain}"
6b8cff41
MT
1853 cat doc/make.sh-usage
1854 ;;
3ea75603 1855esac