Hinzugefuegt:
[people/pmueller/ipfire-2.x.git] / make.sh
1 #!/bin/bash
2 #
3 ############################################################################
4 # #
5 # This file is part of the IPFire Firewall. #
6 # #
7 # IPFire is free software; you can redistribute it and/or modify #
8 # it under the terms of the GNU General Public License as published by #
9 # the Free Software Foundation; either version 2 of the License, or #
10 # (at your option) any later version. #
11 # #
12 # IPFire is distributed in the hope that it will be useful, #
13 # but WITHOUT ANY WARRANTY; without even the implied warranty of #
14 # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the #
15 # GNU General Public License for more details. #
16 # #
17 # You should have received a copy of the GNU General Public License #
18 # along with IPFire; if not, write to the Free Software #
19 # Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA #
20 # #
21 # Copyright (C) 2006 IPFire-Team <entwickler@ipfire.org>. #
22 # #
23 ############################################################################
24 #
25
26 NAME="IPFire" # Software name
27 SNAME="ipfire" # Short name
28 VERSION="2.0" # Version number
29 SLOGAN="www.ipfire.org" # Software slogan
30 CONFIG_ROOT=/var/ipfire # Configuration rootdir
31 NICE=10
32 MAX_RETRIES=3 # prefetch/check loop
33 KVER=`grep --max-count=1 VER lfs/linux | awk '{ print $3 }'`
34 MACHINE=`uname -m`
35 SVN_REVISION=`svn info | grep Revision | cut -c 11-`
36
37 # Setzen des IPFire Builds
38 if [ -e ./.svn ]; then
39 FIREBUILD=`cat .svn/entries |sed -n 's/^[ \t]*revision=\"// p' | sed -n 's/\".*$// p'`
40 fi
41
42 # Debian specific settings
43 if [ ! -e /etc/debian_version ]; then
44 FULLPATH=`which $0`
45 else
46 if [ -x /usr/bin/realpath ]; then
47 FULLPATH=`/usr/bin/realpath $0`
48 else
49 echo "ERROR: Need to do apt-get install realpath"
50 exit 1
51 fi
52 fi
53
54 PWD=`pwd`
55 BASENAME=`basename $0`
56 BASEDIR=`echo $FULLPATH | sed "s/\/$BASENAME//g"`
57 LOGFILE=$BASEDIR/log/_build.preparation.log
58 export BASEDIR LOGFILE
59 DIR_CHK=$BASEDIR/cache/check
60 mkdir $BASEDIR/log/ 2>/dev/null
61
62 if [ -f .config ]; then
63 . .config
64 fi
65
66 if [ 'x86_64' = $MACHINE -o 'i686' = $MACHINE -o 'i586' = $MACHINE -o 'i486' = $MACHINE -o 'i386' = $MACHINE ]; then
67 echo "`date -u '+%b %e %T'`: Machine is ix86 (or equivalent)" >> $LOGFILE
68 MACHINE=i386
69 BUILDTARGET=i386-pc-linux-gnu
70 CFLAGS="-O2 -mcpu=i386 -march=i386 -pipe -fomit-frame-pointer"
71 CXXFLAGS="-O2 -mcpu=i386 -march=i386 -pipe -fomit-frame-pointer"
72 elif [ 'alpha' = $MACHINE ]; then
73 echo "`date -u '+%b %e %T'`: Machine is Alpha AXP" >> $LOGFILE
74 BUILDTARGET=alpha-unknown-linux-gnu
75 CFLAGS="-O2 -mcpu=ev4 -mieee -pipe"
76 CXXFLAGS="-O2 -mcpu=ev4 -mieee -pipe"
77 else
78 echo "`date -u '+%b %e %T'`: Can't determine your architecture - $MACHINE" >> $LOGFILE
79 exit 1
80 fi
81
82 # Define immediately
83 stdumount() {
84 umount $BASEDIR/build/dev/pts 2>/dev/null;
85 umount $BASEDIR/build/proc 2>/dev/null;
86 umount $BASEDIR/build/install/mnt 2>/dev/null;
87 umount $BASEDIR/build/usr/src/cache 2>/dev/null;
88 umount $BASEDIR/build/usr/src/ccache 2>/dev/null;
89 umount $BASEDIR/build/usr/src/config 2>/dev/null;
90 umount $BASEDIR/build/usr/src/doc 2>/dev/null;
91 umount $BASEDIR/build/usr/src/html 2>/dev/null;
92 umount $BASEDIR/build/usr/src/langs 2>/dev/null;
93 umount $BASEDIR/build/usr/src/lfs 2>/dev/null;
94 umount $BASEDIR/build/usr/src/log 2>/dev/null;
95 umount $BASEDIR/build/usr/src/src 2>/dev/null;
96 }
97
98 exiterror() {
99 stdumount
100 for i in `seq 0 7`; do
101 if ( losetup /dev/loop${i} 2>/dev/null | grep -q "/install/images" ); then
102 losetup -d /dev/loop${i} 2>/dev/null
103 fi;
104 done
105 echo "ERROR: $*"
106 echo " Check $LOGFILE for errors if applicable"
107 exit 1
108 }
109
110 entershell() {
111 if [ ! -e $BASEDIR/build/usr/src/lfs/ ]; then
112 exiterror "No such file or directory: $BASEDIR/build/usr/src/lfs/"
113 fi
114 echo "Entering to a shell inside LFS chroot, go out with exit"
115 chroot $LFS /tools/bin/env -i HOME=/root TERM=$TERM PS1='\u:\w\$ ' \
116 PATH=/usr/local/bin:/bin:/usr/bin:/sbin:/usr/sbin:/tools/bin \
117 VERSION=$VERSION CONFIG_ROOT=$CONFIG_ROOT \
118 NAME="$NAME" SNAME="$SNAME" SLOGAN="$SLOGAN" \
119 CFLAGS="$CFLAGS" CXXFLAGS="$CXXFLAGS" \
120 CCACHE_DIR=/usr/src/ccache \
121 CCACHE_HASHDIR=1 \
122 KVER=$KVER \
123 BUILDTARGET="$BUILDTARGET" MACHINE="$MACHINE" \
124 KGCC="ccache /usr/bin/gcc" \
125 /tools/bin/bash
126 if [ $? -ne 0 ]; then
127 exiterror "chroot error"
128 else
129 stdumount
130 fi
131 }
132
133 prepareenv() {
134 ############################################################################
135 # #
136 # Are we running the right shell? #
137 # #
138 ############################################################################
139 if [ ! "$BASH" ]; then
140 exiterror "BASH environment variable is not set. You're probably running the wrong shell."
141 fi
142
143 if [ -z "${BASH_VERSION}" ]; then
144 exiterror "Not running BASH shell."
145 fi
146
147
148 ############################################################################
149 # #
150 # Trap on emergency exit #
151 # #
152 ############################################################################
153 trap "exiterror 'Build process interrupted'" SIGINT SIGTERM SIGKILL SIGSTOP SIGQUIT
154
155
156 ############################################################################
157 # #
158 # Resetting our nice level #
159 # #
160 ############################################################################
161 echo "`date -u '+%b %e %T'`: Resetting our nice level to $NICE" | tee -a $LOGFILE
162 renice $NICE $$ > /dev/null
163 if [ `nice` != "$NICE" ]; then
164 exiterror "Failed to set correct nice level"
165 fi
166
167 ############################################################################
168 # #
169 # Checking if running as root user #
170 # #
171 ############################################################################
172 echo "`date -u '+%b %e %T'`: Checking if we're running as root user" | tee -a $LOGFILE
173 if [ `id -u` != 0 ]; then
174 exiterror "Not building as root"
175 fi
176
177
178 ############################################################################
179 # #
180 # Checking for necessary temporary space #
181 # #
182 ############################################################################
183 echo "`date -u '+%b %e %T'`: Checking for necessary space on disk $BASE_DEV" | tee -a $LOGFILE
184 BASE_DEV=`df -P -k $BASEDIR | tail -n 1 | awk '{ print $1 }'`
185 BASE_ASPACE=`df -P -k $BASEDIR | tail -n 1 | awk '{ print $4 }'`
186 if (( 2202000 > $BASE_ASPACE )); then
187 BASE_USPACE=`du -skx $BASEDIR | awk '{print $1}'`
188 if (( 2202000 - $BASE_USPACE > $BASE_ASPACE )); then
189 exiterror "Not enough temporary space available, need at least 2.1GB on $BASE_DEV"
190 fi
191 fi
192
193 ############################################################################
194 # #
195 # Building Linux From Scratch system #
196 # #
197 ############################################################################
198 echo "`date -u '+%b %e %T'`: Building Linux From Scratch system" | tee -a $LOGFILE
199
200 # Set umask
201 umask 022
202
203 # Set LFS Directory
204 LFS=$BASEDIR/build
205
206 # Check /tools symlink
207 if [ -h /tools ]; then
208 rm -f /tools
209 fi
210 if [ ! -a /tools ]; then
211 ln -s $BASEDIR/build/tools /
212 fi
213 if [ ! -h /tools ]; then
214 exiterror "Could not create /tools symbolic link."
215 fi
216
217 # Setup environment
218 set +h
219 LC_ALL=POSIX
220 export LFS LC_ALL CFLAGS CXXFLAGS
221 unset CC CXX CPP LD_LIBRARY_PATH LD_PRELOAD
222
223 # Make some extra directories
224 mkdir -p $BASEDIR/build/{tools,etc,usr/src} 2>/dev/null
225 mkdir -p $BASEDIR/{cache,ccache} 2>/dev/null
226 mkdir -p $BASEDIR/build/dev/pts $BASEDIR/build/proc $BASEDIR/build/usr/src/{cache,config,doc,html,langs,lfs,log,src,ccache}
227
228 # Make all sources and proc available under lfs build
229 mount --bind /dev/pts $BASEDIR/build/dev/pts
230 mount --bind /proc $BASEDIR/build/proc
231 mount --bind $BASEDIR/cache $BASEDIR/build/usr/src/cache
232 mount --bind $BASEDIR/ccache $BASEDIR/build/usr/src/ccache
233 mount --bind $BASEDIR/config $BASEDIR/build/usr/src/config
234 mount --bind $BASEDIR/doc $BASEDIR/build/usr/src/doc
235 mount --bind $BASEDIR/html $BASEDIR/build/usr/src/html
236 mount --bind $BASEDIR/langs $BASEDIR/build/usr/src/langs
237 mount --bind $BASEDIR/lfs $BASEDIR/build/usr/src/lfs
238 mount --bind $BASEDIR/log $BASEDIR/build/usr/src/log
239 mount --bind $BASEDIR/src $BASEDIR/build/usr/src/src
240
241 # Run LFS static binary creation scripts one by one
242 export CCACHE_DIR=$BASEDIR/ccache
243 export CCACHE_HASHDIR=1
244
245 # Remove pre-install list of installed files in case user erase some files before rebuild
246 rm -f $BASEDIR/build/usr/src/lsalr 2>/dev/null
247 }
248
249
250 ############################################################################
251 # #
252 # Necessary shell functions #
253 # #
254 ############################################################################
255 lfsmake1() {
256 if [ -f $BASEDIR/lfs/$1 ]; then
257 echo "`date -u '+%b %e %T'`: Building $*" | tee -a $LOGFILE
258 cd $BASEDIR/lfs && make -s -f $* LFS_BASEDIR=$BASEDIR MESSAGE="$1\t " download >> $LOGFILE 2>&1
259 if [ $? -ne 0 ]; then
260 exiterror "Download error in $1"
261 fi
262 cd $BASEDIR/lfs && make -s -f $* LFS_BASEDIR=$BASEDIR MESSAGE="$1\t md5sum" md5 >> $LOGFILE 2>&1
263 if [ $? -ne 0 ]; then
264 exiterror "md5sum error in $1, check file in cache or signature"
265 fi
266 cd $BASEDIR/lfs && make -f $* BUILDTARGET=$BUILDTARGET \
267 MACHINE=$MACHINE \
268 LFS_BASEDIR=$BASEDIR \
269 ROOT=$LFS \
270 KVER=$KVER \
271 install >> $LOGFILE 2>&1
272 if [ $? -ne 0 ]; then
273 exiterror "Building $*";
274 fi
275 else
276 exiterror "No such file or directory: $BASEDIR/$1"
277 fi
278 return 0
279 }
280
281 lfsmake2() {
282 if [ -f $BASEDIR/build/usr/src/lfs/$1 ]; then
283 echo "`date -u '+%b %e %T'`: Building $*" | tee -a $LOGFILE
284 cd $BASEDIR/lfs && make -s -f $* LFS_BASEDIR=$BASEDIR MESSAGE="$1\t " download >> $LOGFILE 2>&1
285 if [ $? -ne 0 ]; then
286 exiterror "Download error in $1"
287 fi
288 cd $BASEDIR/lfs && make -s -f $* LFS_BASEDIR=$BASEDIR MESSAGE="$1\t md5sum" md5 >> $LOGFILE 2>&1
289 if [ $? -ne 0 ]; then
290 exiterror "md5sum error in $1, check file in cache or signature"
291 fi
292 chroot $LFS /tools/bin/env -i HOME=/root \
293 TERM=$TERM PS1='\u:\w\$ ' \
294 PATH=/usr/local/bin:/bin:/usr/bin:/sbin:/usr/sbin:/tools/bin \
295 VERSION=$VERSION \
296 CONFIG_ROOT=$CONFIG_ROOT \
297 NAME="$NAME" SNAME="$SNAME" SLOGAN="$SLOGAN" \
298 CFLAGS="$CFLAGS" CXXFLAGS="$CXXFLAGS" \
299 CCACHE_DIR=/usr/src/ccache CCACHE_HASHDIR=1 \
300 KVER=$KVER \
301 BUILDTARGET="$BUILDTARGET" MACHINE="$MACHINE" \
302 /tools/bin/bash -x -c "cd /usr/src/lfs && \
303 make -f $* LFS_BASEDIR=/usr/src install" >>$LOGFILE 2>&1
304 if [ $? -ne 0 ]; then
305 exiterror "Building $*"
306 fi
307 else
308 exiterror "No such file or directory: $BASEDIR/build/usr/src/lfs/$1"
309 fi
310 return 0
311 }
312
313 ipcopmake() {
314 if [ -f $BASEDIR/build/usr/src/lfs/$1 ]; then
315 echo "`date -u '+%b %e %T'`: Building $*" | tee -a $LOGFILE
316 cd $BASEDIR/lfs && make -s -f $* LFS_BASEDIR=$BASEDIR MESSAGE="$1\t " download >> $LOGFILE 2>&1
317 if [ $? -ne 0 ]; then
318 exiterror "Download error in $1"
319 fi
320 cd $BASEDIR/lfs && make -s -f $* LFS_BASEDIR=$BASEDIR MESSAGE="$1\t md5sum" md5 >> $LOGFILE 2>&1
321 if [ $? -ne 0 ]; then
322 exiterror "md5sum error in $1, check file in cache or signature"
323 fi
324 chroot $LFS /tools/bin/env -i HOME=/root \
325 TERM=$TERM PS1='\u:\w\$ ' \
326 PATH=/usr/local/bin:/bin:/usr/bin:/sbin:/usr/sbin \
327 VERSION=$VERSION \
328 CONFIG_ROOT=$CONFIG_ROOT \
329 NAME="$NAME" SNAME="$SNAME" SLOGAN="$SLOGAN" \
330 CFLAGS="$CFLAGS" CXXFLAGS="$CXXFLAGS" \
331 CCACHE_DIR=/usr/src/ccache CCACHE_HASHDIR=1 \
332 KVER=$KVER \
333 BUILDTARGET="$BUILDTARGET" MACHINE="$MACHINE" \
334 /bin/bash -x -c "cd /usr/src/lfs && \
335 make -f $* LFS_BASEDIR=/usr/src install" >>$LOGFILE 2>&1
336 if [ $? -ne 0 ]; then
337 exiterror "Building $*"
338 fi
339 else
340 exiterror "No such file or directory: $BASEDIR/build/usr/src/lfs/$1"
341 fi
342 return 0
343 }
344
345 ipfiredist() {
346 if [ -f $BASEDIR/build/usr/src/lfs/$1 ]; then
347 # if [ ! `ls -w1 $BASEDIR/packages/*.ipfire | grep $1` ]; then
348 echo "`date -u '+%b %e %T'`: Packaging $1" | tee -a $LOGFILE
349 chroot $LFS /tools/bin/env -i HOME=/root \
350 TERM=$TERM PS1='\u:\w\$ ' \
351 PATH=/usr/local/bin:/bin:/usr/bin:/sbin:/usr/sbin \
352 VERSION=$VERSION \
353 CONFIG_ROOT=$CONFIG_ROOT \
354 NAME="$NAME" SNAME="$SNAME" SLOGAN="$SLOGAN" \
355 CFLAGS="$CFLAGS" CXXFLAGS="$CXXFLAGS" \
356 CCACHE_DIR=/usr/src/ccache CCACHE_HASHDIR=1 \
357 KVER=$KVER \
358 BUILDTARGET="$BUILDTARGET" MACHINE="$MACHINE" \
359 /bin/bash -x -c "cd /usr/src/lfs && \
360 make -f $1 LFS_BASEDIR=/usr/src dist" >>$LOGFILE 2>&1
361 if [ $? -ne 0 ]; then
362 exiterror "Packaging $1"
363 fi
364 # else
365 # echo "`date -u '+%b %e %T'`: Packaging: The package $1 already exists"
366 # fi
367 else
368 exiterror "No such file or directory: $BASEDIR/build/usr/src/lfs/$1"
369 fi
370 return 0
371 }
372
373
374 installmake() {
375 if [ -f $BASEDIR/build/usr/src/lfs/$1 ]; then
376 echo "`date -u '+%b %e %T'`: Building $*" | tee -a $LOGFILE
377 cd $BASEDIR/lfs && make -s -f $* LFS_BASEDIR=$BASEDIR MESSAGE="$1\t " download >> $LOGFILE 2>&1
378 if [ $? -ne 0 ]; then
379 exiterror "Download error in $1"
380 fi
381 cd $BASEDIR/lfs && make -s -f $* LFS_BASEDIR=$BASEDIR MESSAGE="$1\t md5sum" md5 >> $LOGFILE 2>&1
382 if [ $? -ne 0 ]; then
383 exiterror "md5sum error in $1, check file in cache or signature"
384 fi
385 chroot $LFS /tools/bin/env -i HOME=/root \
386 TERM=$TERM PS1='\u:\w\$ ' \
387 PATH=/usr/local/bin:/opt/$MACHINE-uClibc/usr/bin:/bin:/usr/bin:/sbin:/usr/sbin \
388 VERSION=$VERSION \
389 CONFIG_ROOT=$CONFIG_ROOT \
390 LFS_PASS="install" \
391 NAME="$NAME" SNAME="$SNAME" SLOGAN="$SLOGAN" \
392 CFLAGS="-Os" CXXFLAGS="-Os" \
393 CCACHE_DIR=/usr/src/ccache CCACHE_HASHDIR=1 \
394 KVER=$KVER \
395 BUILDTARGET="$BUILDTARGET" MACHINE="$MACHINE" \
396 /bin/bash -x -c "cd /usr/src/lfs && \
397 make -f $* LFS_BASEDIR=/usr/src install" >>$LOGFILE 2>&1
398 if [ $? -ne 0 ]; then
399 exiterror "Building $*"
400 fi
401 else
402 exiterror "No such file or directory: $BASEDIR/build/usr/src/lfs/$1"
403 fi
404 return 0
405 }
406
407 buildtoolchain() {
408 LOGFILE="$BASEDIR/log/_build.toolchain.log"
409 export LOGFILE
410 echo -ne "`date -u '+%b %e %T'`: Stage1 toolchain build \n" | tee -a $LOGFILE
411 # Build sed now, as we use some extensions
412 ORG_PATH=$PATH
413 NATIVEGCC=`gcc --version | grep GCC | awk {'print $3'}`
414 export NATIVEGCC GCCmajor=${NATIVEGCC:0:1} GCCminor=${NATIVEGCC:2:1} GCCrelease=${NATIVEGCC:4:1}
415 lfsmake1 ccache
416 lfsmake1 sed LFS_PASS=1
417 lfsmake1 m4 LFS_PASS=1
418 lfsmake1 bison LFS_PASS=1
419 lfsmake1 flex LFS_PASS=1
420 lfsmake1 binutils LFS_PASS=1
421 lfsmake1 gcc LFS_PASS=1
422 export PATH=$BASEDIR/build/usr/local/bin:$BASEDIR/build/tools/bin:$PATH
423
424 lfsmake1 linux
425 lfsmake1 tcl
426 lfsmake1 expect
427 lfsmake1 glibc
428 lfsmake1 dejagnu
429 lfsmake1 gcc LFS_PASS=2
430 lfsmake1 binutils LFS_PASS=2
431 lfsmake1 gawk
432 lfsmake1 coreutils
433 lfsmake1 bzip2
434 lfsmake1 gzip
435 lfsmake1 diffutils
436 lfsmake1 findutils
437 lfsmake1 make
438 lfsmake1 grep
439 lfsmake1 sed LFS_PASS=2
440 lfsmake1 m4 LFS_PASS=2
441 lfsmake1 bison LFS_PASS=2
442 lfsmake1 flex LFS_PASS=2
443 lfsmake1 gettext
444 lfsmake1 ncurses
445 lfsmake1 patch
446 lfsmake1 tar
447 lfsmake1 texinfo
448 lfsmake1 bash
449 lfsmake1 util-linux
450 lfsmake1 perl
451 export PATH=$ORG_PATH
452 }
453
454 buildbase() {
455 LOGFILE="$BASEDIR/log/_build.base.log"
456 export LOGFILE
457 echo -ne "`date -u '+%b %e %T'`: Stage2 linux base build \n" | tee -a $LOGFILE
458 # Run LFS dynamic binary creation scripts one by one
459 lfsmake2 stage2
460 lfsmake2 makedev
461 lfsmake2 linux
462 lfsmake2 man-pages
463 lfsmake2 glibc
464 lfsmake2 binutils
465 lfsmake2 gcc
466 lfsmake2 coreutils
467 lfsmake2 zlib
468 lfsmake2 mktemp
469 lfsmake2 iana-etc
470 lfsmake2 findutils
471 lfsmake2 gawk
472 lfsmake2 ncurses
473 lfsmake2 vim
474 lfsmake2 m4
475 lfsmake2 bison
476 lfsmake2 less
477 lfsmake2 groff
478 lfsmake2 sed
479 lfsmake2 flex
480 lfsmake2 gettext
481 lfsmake2 net-tools
482 lfsmake2 inetutils
483 lfsmake2 perl
484 lfsmake2 texinfo
485 lfsmake2 autoconf
486 lfsmake2 automake
487 lfsmake2 bash
488 lfsmake2 file
489 lfsmake2 libtool
490 lfsmake2 bzip2
491 lfsmake2 diffutils
492 lfsmake2 ed
493 lfsmake2 kbd
494 lfsmake2 e2fsprogs
495 lfsmake2 grep
496 if [ 'i386' = $MACHINE ]; then
497 lfsmake2 grub
498 elif [ 'alpha' = $MACHINE ]; then
499 lfsmake2 aboot
500 fi
501 lfsmake2 gzip
502 lfsmake2 man
503 lfsmake2 make
504 lfsmake2 modutils
505 lfsmake2 patch
506 lfsmake2 procinfo
507 lfsmake2 procps
508 lfsmake2 psmisc
509 lfsmake2 shadow
510 lfsmake2 sysklogd
511 lfsmake2 sysvinit
512 lfsmake2 tar
513 lfsmake2 util-linux
514 }
515
516 buildipcop() {
517 # Run IPFire make scripts one by one
518 LOGFILE="$BASEDIR/log/_build.ipfire.log"
519 export LOGFILE
520 echo -ne "`date -u '+%b %e %T'`: Stage3 $NAME build \n" | tee -a $LOGFILE
521
522 # Build these first as some of the kernel packages below rely on
523 # these for some of their client program functionality
524 ipcopmake configroot
525 ipcopmake dhcp
526 ipcopmake dhcpcd
527 ipcopmake libusb
528 ipcopmake libpcap
529 ipcopmake linux-atm
530 ipcopmake ppp
531 ipcopmake rp-pppoe
532 ipcopmake unzip
533 # Do SMP now
534 if [ 'i386' = $MACHINE ]; then
535 # abuse the SMP flag, and make an minimal installer kernel first
536 # so that the boot floppy always works.....
537 ipcopmake linux LFS_PASS=ipfire SMP=installer
538 ipcopmake linux LFS_PASS=ipfire SMP=1
539 ipcopmake 3cp4218 SMP=1
540 ipcopmake amedyn SMP=1
541 ipcopmake cxacru SMP=1
542 ipcopmake eagle SMP=1
543
544 # These are here because they have i386 only binary libraries
545 # included in the package.
546 ipcopmake cnx_pci SMP=1
547 ipcopmake fcdsl SMP=1
548 ipcopmake fcdsl2 SMP=1
549 ipcopmake fcdslsl SMP=1
550 ipcopmake fcdslusb SMP=1
551 ipcopmake fcdslslusb SMP=1
552 ipcopmake fcpci SMP=1
553 ipcopmake fcclassic SMP=1
554 ipcopmake pulsar SMP=1
555 ipcopmake unicorn SMP=1
556 ipcopmake promise-sata-300-tx SMP=1
557 fi
558
559 ipcopmake linux LFS_PASS=ipfire
560 ipcopmake 3cp4218
561 ipcopmake amedyn
562 ipcopmake cxacru
563 ipcopmake eciadsl
564 ipcopmake eagle
565 ipcopmake speedtouch
566 if [ 'i386' = $MACHINE ]; then
567 # These are here because they have i386 only binary libraries
568 # included in the package.
569 ipcopmake cnx_pci
570 ipcopmake fcdsl
571 ipcopmake fcdsl2
572 ipcopmake fcdslsl
573 ipcopmake fcdslusb
574 ipcopmake fcdslslusb
575 ipcopmake fcpci
576 ipcopmake fcclassic
577 ipcopmake pulsar
578 ipcopmake unicorn
579 ipcopmake promise-sata-300-tx
580 fi
581
582 ipcopmake pcmcia-cs
583 ipcopmake expat
584 ipcopmake gdbm
585 ipcopmake gmp
586 ipcopmake openssl
587 ipcopmake python
588 ipcopmake libnet
589 ipcopmake libpng
590 ipcopmake libtiff
591 ipcopmake libjpeg
592 ipcopmake lcms
593 ipcopmake libmng
594 ipcopmake freetype
595 ipcopmake gd
596 ipcopmake popt
597 ipcopmake slang
598 ipcopmake newt
599 ipcopmake libcap
600 ipcopmake pciutils
601 ipcopmake pcre
602 ipcopmake readline
603 ipcopmake berkeley
604 ipcopmake BerkeleyDB ## The Perl module
605 ipcopmake mysql
606 ipcopmake saslauthd PASS=1
607 ipcopmake openldap
608 ipcopmake apache
609 ipcopmake apache2
610 ipcopmake php
611 ipcopmake arping
612 ipcopmake beep
613 ipcopmake bind
614 ipcopmake capi4k-utils
615 ipcopmake cdrtools
616 ipcopmake dnsmasq
617 ipcopmake dosfstools
618 ipcopmake ethtool
619 ipcopmake ez-ipupdate
620 ipcopmake fcron
621 ipcopmake perl-GD
622 ipcopmake gnupg
623 ipcopmake hdparm
624 ipcopmake ibod
625 ipcopmake initscripts
626 ipcopmake iptables
627 ipcopmake ipac-ng
628 ipcopmake ipaddr
629 ipcopmake iproute2
630 ipcopmake iptstate
631 ipcopmake iputils
632 ipcopmake l7-protocols
633 ipcopmake isapnptools
634 ipcopmake isdn4k-utils
635 ipcopmake kudzu
636 ipcopmake logrotate
637 ipcopmake logwatch
638 ipcopmake mingetty
639 ipcopmake misc-progs
640 ipcopmake mtools
641 ipcopmake nano
642 ipcopmake nash
643 ipcopmake nasm
644 ipcopmake URI
645 ipcopmake HTML-Tagset
646 ipcopmake HTML-Parser
647 ipcopmake Compress-Zlib
648 ipcopmake Digest
649 ipcopmake Digest-SHA1
650 ipcopmake Digest-HMAC
651 ipcopmake libwww-perl
652 ipcopmake Net-DNS
653 ipcopmake Net-IPv4Addr
654 ipcopmake Net_SSLeay
655 ipcopmake IO-Stringy
656 ipcopmake Unix-Syslog
657 ipcopmake Mail-Tools
658 ipcopmake MIME-Tools
659 ipcopmake Net-Server
660 ipcopmake Convert-TNEF
661 ipcopmake Convert-UUlib
662 ipcopmake Archive-Tar
663 ipcopmake Archive-Zip
664 ipcopmake Text-Tabs+Wrap
665 ipcopmake Locale-Country
666 ipcopmake GeoIP
667 ipcopmake fwhits
668 ipcopmake noip_updater
669 ipcopmake ntp
670 ipcopmake oinkmaster
671 ipcopmake openssh
672 ipcopmake openswan
673 ipcopmake pptpclient
674 ipcopmake rrdtool
675 ipcopmake setserial
676 ipcopmake setup
677 ipcopmake snort
678 #ipcopmake speedycgi
679 ipcopmake squid
680 ipcopmake squid-graph
681 ipcopmake squidguard
682 ipcopmake tcpdump
683 ipcopmake traceroute
684 ipcopmake vlan
685 #ipcopmake wireless
686 ipcopmake libsafe
687 ipcopmake 3c5x9setup
688 # echo -ne "`date -u '+%b %e %T'`: Building ### IPFire modules ### \n" | tee -a $LOGFILE
689 ipcopmake pakfire
690 ipcopmake startscripts
691 ## Zuerst die Libs und dann die Programme. Ordnung muss sein!
692 ipcopmake java
693 ipcopmake bootsplash
694 ipcopmake libxml2
695 ipcopmake spandsp
696 ipcopmake lzo
697 ipcopmake openvpn
698 ipcopmake pkg-config
699 ipcopmake glib
700 ipcopmake xampp
701 ipcopmake pam
702 ipcopmake pammysql
703 ipcopmake saslauthd PASS=2
704 ipcopmake xinetd
705 ipcopmake ghostscript
706 ipcopmake cups
707 # ipcopmake lpd ## Im Moment aus, da CUPS vorhanden ist.
708 ipcopmake samba
709 ipcopmake sudo
710 ipcopmake mc
711 # ipcopmake pwlib
712 # ipcopmake openh323
713 ipcopmake wget
714 ipcopmake wput
715 ipcopmake bridge-utils
716 ipcopmake screen
717 ipcopmake hddtemp
718 ipcopmake smartmontools
719 ipcopmake htop
720 ipcopmake lynx
721 echo -ne "`date -u '+%b %e %T'`: Building ### Mailserver ### \n" | tee -a $LOGFILE
722 ipcopmake postfix
723 ipcopmake procmail
724 ipcopmake fetchmail
725 ipcopmake cyrusimap
726 ipcopmake web-cyradm
727 ipcopmake mailx
728 ipcopmake clamav
729 ipcopmake razor
730 ipcopmake spamassassin
731 # ipcopmake amavisd
732 echo -ne "`date -u '+%b %e %T'`: Building ### VoIP-Server ### \n" | tee -a $LOGFILE
733 ipcopmake stund
734 ipcopmake zaptel
735 ipcopmake libpri
736 ipcopmake bristuff
737 ipcopmake asterisk
738 ipcopmake mpg123
739 echo -ne "`date -u '+%b %e %T'`: Building ### Multimedia-Server ### \n" | tee -a $LOGFILE
740 ipcopmake libmad
741 ipcopmake libogg
742 ipcopmake libvorbis
743 ipcopmake lame
744 ipcopmake xvid
745 ipcopmake mpeg2dec
746 ipcopmake ffmpeg
747 ipcopmake sox
748 ipcopmake gnump3d
749 ipcopmake videolan
750 echo -ne "`date -u '+%b %e %T'`: Building ### P2P-Clients ### \n" | tee -a $LOGFILE
751 ipcopmake applejuice
752 ipcopmake ocaml
753 ipcopmake mldonkey
754 # ipcopmake edonkeyclc
755 # ipcopmake sane
756 echo -ne "`date -u '+%b %e %T'`: Building ### Net-Tools ### \n" | tee -a $LOGFILE
757 ipcopmake ntop
758 # ipcopmake rsync
759 ipcopmake tcpwrapper
760 ipcopmake portmap
761 ipcopmake nfs
762 ipcopmake nmap
763 ipcopmake mbmon
764 ipcopmake iftop
765 ipcopmake ncftp
766 ipcopmake cftp
767 ipcopmake etherwake
768 ipcopmake ethereal
769 ipcopmake tftp-hpa
770 ipcopmake subversion
771 ipcopmake iptraf
772 ipcopmake nagios
773 # ipcopmake stunnel # Ausgeschaltet, weil wir es doch nicht nutzen
774 }
775
776 buildinstaller() {
777 # Run installer scripts one by one
778 LOGFILE="$BASEDIR/log/_build.installer.log"
779 export LOGFILE
780 echo -ne "`date -u '+%b %e %T'`: Stage4 installer build \n" | tee -a $LOGFILE
781 if [ 'i386' = $MACHINE ]; then
782 ipcopmake syslinux
783 ipcopmake as86
784 ipcopmake mbr
785 ipcopmake uClibc
786 fi
787 installmake busybox
788 installmake sysvinit
789 installmake e2fsprogs
790 installmake misc-progs
791 installmake slang
792 installmake util-linux
793 installmake newt
794 installmake pciutils
795 installmake pcmcia-cs
796 installmake kbd
797 installmake installer
798 installmake scsi.img
799 installmake driver.img
800 installmake initrd
801 installmake boot.img
802 }
803
804 buildpackages() {
805 LOGFILE="$BASEDIR/log/_build.packages.log"
806 export LOGFILE
807 echo "... see detailed log in _build.*.log files" >> $LOGFILE
808 echo -ne "`date -u '+%b %e %T'`: Stage5 packages build \n" | tee -a $LOGFILE
809 # Strip files
810 echo "`date -u '+%b %e %T'`: Stripping files" | tee -a $LOGFILE
811 find $LFS/lib $LFS/usr/lib $LFS/usr/share/rrdtool-* $LFS/install ! -type l \( -name '*.so' -o -name '*.so[\.0-9]*' \) \
812 ! -name 'libc.so' ! -name 'libpthread.so' ! -name 'libcrypto.so.0.9.7.sha1' \
813 -exec $LFS/tools/bin/strip --strip-all {} \; >> $LOGFILE 2>&1
814 # add -ls before -exec if you want to verify what files are stripped
815
816 find $LFS/{,s}bin $LFS/usr/{,s}bin $LFS/usr/local/{,s}bin ! -type l \
817 -exec file {} \; | grep " ELF " | cut -f1 -d ':' | xargs $LFS/tools/bin/strip --strip-all >> $LOGFILE 2>&1
818 # there add -v to strip to verify
819
820 if [ 'i386' = $MACHINE ]; then
821 # Create fcdsl packages
822 echo "`date -u '+%b %e %T'`: Building fcdsl tgz" | tee -a $LOGFILE
823 cp $LFS/install/images/fcdsl/license.txt $LFS >> $LOGFILE 2>&1
824 touch $LFS/var/run/{need-depmod-$KVER,need-depmod-$KVER-smp}
825 cd $LFS && tar cvfz $LFS/install/images/$SNAME-fcdsl-$VERSION.$MACHINE.tgz \
826 lib/modules/$KVER/misc/fcdsl*.o.gz \
827 lib/modules/$KVER-smp/misc/fcdsl*.o.gz \
828 usr/lib/isdn/{fds?base.bin,fd?ubase.frm} \
829 etc/fcdsl/fcdsl*.conf \
830 etc/drdsl/{drdsl,drdsl.ini} \
831 license.txt \
832 var/run/{need-depmod-$KVER,need-depmod-$KVER-smp} >> $LOGFILE 2>&1
833 rm -f $LFS/license.txt >> $LOGFILE 2>&1
834 cd $BASEDIR
835 fi
836
837 # Generating list of packages used
838 echo "`date -u '+%b %e %T'`: Generating packages list from logs" | tee -a $LOGFILE
839 rm -f $BASEDIR/doc/packages-list
840 for i in `ls -1tr $BASEDIR/log/[^_]*`; do
841 if [ "$i" != "$BASEDIR/log/FILES" -a -n $i ]; then
842 echo " * `basename $i`" >>$BASEDIR/doc/packages-list
843 fi
844 done
845 echo "====== List of softwares used to build $NAME Version: $VERSION ======" > $BASEDIR/doc/packages-list.txt
846 grep -v 'configroot$\|img$\|initrd$\|initscripts$\|installer$\|install$\|ipfire$\|setup$\|pakfire$\|stage2$\|smp$\|tools$\|tools1$\|tools2$\|^ipfire-logs' \
847 $BASEDIR/doc/packages-list | sort >> $BASEDIR/doc/packages-list.txt
848 rm -f $BASEDIR/doc/packages-list
849 # packages-list.txt is ready to be displayed for wiki page
850
851 # Create ISO for CDRom and USB-superfloppy
852 ipcopmake cdrom
853 rm -f $LFS/install/images/*usb*
854 cp $LFS/install/images/{*.iso,*.tgz} $BASEDIR >> $LOGFILE 2>&1
855
856 ipfirepackages
857
858 # Cleanup
859 stdumount
860 rm -rf $BASEDIR/build/tmp/*
861
862 # Generating total list of files
863 echo "`date -u '+%b %e %T'`: Generating files list from logs" | tee -a $LOGFILE
864 rm -f $BASEDIR/log/FILES
865 for i in `ls -1tr $BASEDIR/log/[^_]*`; do
866 if [ "$i" != "$BASEDIR/log/FILES" -a -n $i ]; then
867 echo "##" >>$BASEDIR/log/FILES
868 echo "## `basename $i`" >>$BASEDIR/log/FILES
869 echo "##" >>$BASEDIR/log/FILES
870 cat $i | sed "s%^\./%#%" | sort >> $BASEDIR/log/FILES
871 fi
872 done
873 cd $BASEDIR/packages; ls -w1 *.ipfire | awk -F ".ipfire" '{ print $1 }' > $BASEDIR/packages/packages_list.txt
874 echo -n "###EOF###" >> $BASEDIR/packages/packages_list.txt
875
876 cd $PWD
877
878 }
879
880 ipfirepackages() {
881 if [ -d "$BASEDIR/packages" ]; then
882 for i in `ls $BASEDIR/packages`; do
883 touch $BASEDIR/build/install/packages/$i.empty
884 done
885 fi
886 ipfiredist amavisd
887 ipfiredist applejuice
888 ipfiredist asterisk
889 ipfiredist clamav
890 ipfiredist cups
891 ipfiredist cyrusimap
892 ipfiredist fetchmail
893 ipfiredist ffmpeg
894 ipfiredist gnump3d
895 ipfiredist iptraf
896 ipfiredist java
897 ipfiredist lame
898 ipfiredist libmad
899 ipfiredist libogg
900 ipfiredist libtiff
901 ipfiredist libvorbis
902 ipfiredist libxml2
903 ipfiredist mailx
904 ipfiredist mldonkey
905 ipfiredist mpeg2dec
906 ipfiredist nagios
907 ipfiredist nfs
908 ipfiredist nmap
909 ipfiredist ntop
910 ipfiredist portmap
911 ipfiredist postfix
912 ipfiredist procmail
913 ipfiredist samba
914 ipfiredist sox
915 ipfiredist spamassassin
916 ipfiredist subversion
917 ipfiredist videolan
918 ipfiredist web-cyradm
919 ipfiredist xampp
920 # ipfiredist xinetd
921 ipfiredist xvid
922 test -d $BASEDIR/packages || mkdir $BASEDIR/packages
923 mv -f $LFS/install/packages/*.{ipfire,md5} $BASEDIR/packages >> $LOGFILE 2>&1
924 rm -rf $BASEDIR/build/install/packages/*
925 }
926
927 update_logs() {
928 tar cfz log/ipfire-logs-`date +'%Y-%m-%d-%H:%M'`.tgz log/_build.*
929 rm -f log/_build.*
930 }
931
932 # See what we're supposed to do
933 case "$1" in
934 build)
935 BUILDMACHINE=`uname -m`
936 PACKAGE=`ls -v -r $BASEDIR/cache/toolchains/$SNAME-$VERSION-toolchain-$BUILDMACHINE.tar.gz 2> /dev/null | head -n 1`
937 #only restore on a clean disk
938 if [ ! -f log/perl-*-tools ]; then
939 if [ ! -n "$PACKAGE" ]; then
940 echo "`date -u '+%b %e %T'`: Full toolchain compilation" | tee -a $LOGFILE
941 prepareenv
942 buildtoolchain
943 else
944 PACKAGENAME=${PACKAGE%.tar.gz}
945 echo "`date -u '+%b %e %T'`: Restore from $PACKAGE" | tee -a $LOGFILE
946 if [ `md5sum $PACKAGE | awk '{print $1}'` == `cat $PACKAGENAME.md5 | awk '{print $1}'` ]; then
947 tar zxf $PACKAGE
948 prepareenv
949 else
950 exiterror "$PACKAGENAME md5 did not match, check downloaded package"
951 fi
952 fi
953 else
954 echo "`date -u '+%b %e %T'`: Using installed toolchain" | tee -a $LOGFILE
955 prepareenv
956 fi
957
958 buildbase
959 buildipcop
960
961 # Setzen des IPFire Builds
962 if [ "$FIREBUILD" ]; then
963 echo "$FIREBUILD" > $BASEDIR/build/var/ipfire/firebuild
964 else
965 echo "_(OvO)_" > $BASEDIR/build/var/ipfire/firebuild
966 fi
967
968 buildinstaller
969 buildpackages
970 ;;
971 shell)
972 # enter a shell inside LFS chroot
973 # may be used to changed kernel settings
974 prepareenv
975 entershell
976 ;;
977 changelog)
978 echo -n "Loading new Changelog from SVN: "
979 svn log http://svn.ipfire.eu/svn/ipfire > doc/ChangeLog
980 echo "Finished!"
981 ;;
982 check)
983 echo "Checking sources files availability on the web"
984 if [ ! -d $DIR_CHK ]; then
985 mkdir -p $DIR_CHK
986 fi
987 FINISHED=0
988 cd $BASEDIR/lfs
989 for c in `seq $MAX_RETRIES`; do
990 if (( FINISHED==1 )); then
991 break
992 fi
993 FINISHED=1
994 cd $BASEDIR/lfs
995 for i in *; do
996 if [ -f "$i" -a "$i" != "Config" ]; then
997 make -s -f $i MACHINE=$MACHINE LFS_BASEDIR=$BASEDIR ROOT=$BASEDIR/build \
998 MESSAGE="$i\t ($c/$MAX_RETRIES)" check
999 if [ $? -ne 0 ]; then
1000 echo "Check : wget error in lfs/$i"
1001 FINISHED=0
1002 fi
1003 fi
1004 done
1005 done
1006 cd -
1007 ;;
1008 checkclean)
1009 echo "Erasing sources files availability tags"
1010 rm -rf $DIR_CHK/*
1011 ;;
1012 clean)
1013 for i in `mount | grep $BASEDIR | sed 's/^.*loop=\(.*\))/\1/'`; do
1014 $LOSETUP -d $i 2>/dev/null
1015 done
1016 for i in `mount | grep $BASEDIR | cut -d " " -f 1`; do
1017 umount $i
1018 done
1019 stdumount
1020 for i in `seq 0 7`; do
1021 if ( losetup /dev/loop${i} 2>/dev/null | grep -q "/install/images" ); then
1022 umount /dev/loop${i} 2>/dev/null;
1023 losetup -d /dev/loop${i} 2>/dev/null;
1024 fi;
1025 done
1026 rm -rf $BASEDIR/build
1027 rm -rf $BASEDIR/cdrom
1028 rm -rf $BASEDIR/packages
1029 rm -rf $BASEDIR/log
1030 if [ -h /tools ]; then
1031 rm -f /tools
1032 fi
1033 ;;
1034 newpak)
1035 # create structure for a new package
1036 echo -e "Name of the new package: $2"
1037 if [ ! -f "lfs/$2" ]; then
1038 echo "`date -u '+%b %e %T'`: Creating directory src/paks/$2"
1039 mkdir -p src/paks/$2
1040 cd src/paks/$2
1041 echo "`date -u '+%b %e %T'`: Creating files"
1042 cp $BASEDIR/lfs/postfix $BASEDIR/lfs/$2
1043
1044 touch ROOTFILES
1045 touch {,un}install.sh
1046 ## install.sh
1047 echo '#!/bin/bash' > install.sh
1048 echo '#' >> install.sh
1049 echo '#################################################################' >> install.sh
1050 echo '# #' >> install.sh
1051 echo '# This file belongs to IPFire Firewall - GPLv2 - www.ipfire.org #' >> install.sh
1052 echo '# #' >> install.sh
1053 echo '#################################################################' >> install.sh
1054 echo '#' >> install.sh
1055 echo '# Extract the files' >> install.sh
1056 echo 'tar xfz files.tgz -C /' >> install.sh
1057 echo 'cp -f ROOTFILES /opt/pakfire/installed/ROOTFILES.$2' >> install.sh
1058 ## uninstall.sh
1059 echo '#!/bin/bash' > uninstall.sh
1060 echo '#################################################################' >> uninstall.sh
1061 echo '# #' >> uninstall.sh
1062 echo '# This file belongs to IPFire Firewall - GPLv2 - www.ipfire.org #' >> uninstall.sh
1063 echo '# #' >> uninstall.sh
1064 echo '#################################################################' >> uninstall.sh
1065 echo '#' >> uninstall.sh
1066 echo '# Delete the files' >> uninstall.sh
1067 echo '## Befehl fehlt noch' >> uninstall.sh
1068 echo 'rm -f /opt/pakfire/installed/ROOTFILES.$2' >> uninstall.sh
1069 echo "`date -u '+%b %e %T'`: Adding files to SVN"
1070 cd - && svn add lfs/$2 && svn add src/paks/$2
1071
1072 echo -n "Do you want to remove the folders? [y/n]"
1073 read REM
1074 if [ "$REM" == "y" ]; then
1075 echo "Removing the folders..."
1076 svn del src/paks/$2 --force
1077 else
1078 echo "Folders are kept."
1079 fi
1080 else
1081 echo "$2 already exists"
1082 fi
1083 exit 0
1084 ;;
1085 prefetch)
1086 if [ ! -d $BASEDIR/cache ]; then
1087 mkdir $BASEDIR/cache
1088 fi
1089 mkdir -p $BASEDIR/log
1090 echo "`date -u '+%b %e %T'`:Preload all source files" | tee -a $LOGFILE
1091 FINISHED=0
1092 cd $BASEDIR/lfs
1093 for c in `seq $MAX_RETRIES`; do
1094 if (( FINISHED==1 )); then
1095 break
1096 fi
1097 FINISHED=1
1098 cd $BASEDIR/lfs
1099 for i in *; do
1100 if [ -f "$i" -a "$i" != "Config" ]; then
1101 make -s -f $i LFS_BASEDIR=$BASEDIR MESSAGE="$i\t ($c/$MAX_RETRIES)" download >> $LOGFILE 2>&1
1102 if [ $? -ne 0 ]; then
1103 echo "Prefetch : wget error in lfs/$i"
1104 FINISHED=0
1105 else
1106 if [ $c -eq 1 ]; then
1107 echo "Prefetch : lfs/$i files loaded"
1108 fi
1109 fi
1110 fi
1111 done
1112 done
1113 echo "Prefetch : verifying md5sum"
1114 ERROR=0
1115 for i in *; do
1116 if [ -f "$i" -a "$i" != "Config" ]; then
1117 make -s -f $i LFS_BASEDIR=$BASEDIR MESSAGE="$i\t " md5 >> $LOGFILE 2>&1
1118 if [ $? -ne 0 ]; then
1119 echo "md5 difference in lfs/$i"
1120 ERROR=1
1121 fi
1122 fi
1123 done
1124 if [ $ERROR -eq 0 ]; then
1125 echo "Prefetch : all files md5sum match"
1126 fi
1127 cd -
1128 ;;
1129 toolchain)
1130 prepareenv
1131 buildtoolchain
1132 BUILDMACHINE=`uname -m`
1133 echo "`date -u '+%b %e %T'`: Create toolchain tar.gz for $BUILDMACHINE" | tee -a $LOGFILE
1134 test -d $BASEDIR/cache/toolchains || mkdir $BASEDIR/cache/toolchains
1135 cd $BASEDIR && tar -zc --exclude='log/_build.*.log' -f cache/toolchains/$SNAME-$VERSION-toolchain-$BUILDMACHINE.tar.gz \
1136 build/{bin,etc,usr/bin,usr/local} \
1137 build/tools/{bin,etc,*-linux-gnu,include,lib,libexec,sbin,share,var} \
1138 log >> $LOGFILE
1139 md5sum cache/toolchains/$SNAME-$VERSION-toolchain-$BUILDMACHINE.tar.gz \
1140 > cache/toolchains/$SNAME-$VERSION-toolchain-$BUILDMACHINE.md5
1141 stdumount
1142 ;;
1143 gettoolchain)
1144 BUILDMACHINE=`uname -m`
1145 # arbitrary name to be updated in case of new toolchain package upload
1146 PACKAGE=$SNAME-$VERSION-toolchain-$BUILDMACHINE
1147 if [ ! -f $BASEDIR/cache/toolchains/$PACKAGE.tar.gz ]; then
1148 URL_IPFIRE=`grep URL_IPFIRE lfs/Config | awk '{ print $3 }'`
1149 test -d $BASEDIR/cache/toolchains || mkdir $BASEDIR/cache/toolchains
1150 echo "`date -u '+%b %e %T'`: Load toolchain tar.gz for $BUILDMACHINE" | tee -a $LOGFILE
1151 cd $BASEDIR/cache/toolchains
1152 wget $URL_IPFIRE/toolchains/$PACKAGE.tar.gz $URL_IPFIRE/toolchains/$PACKAGE.md5 >& /dev/null
1153 if [ $? -ne 0 ]; then
1154 echo "`date -u '+%b %e %T'`: error downloading toolchain for $BUILDMACHINE machine" | tee -a $LOGFILE
1155 else
1156 if [ "`md5sum $PACKAGE.tar.gz | awk '{print $1}'`" = "`cat $PACKAGE.md5 | awk '{print $1}'`" ]; then
1157 echo "`date -u '+%b %e %T'`: toolchain md5 ok" | tee -a $LOGFILE
1158 else
1159 exiterror "$PACKAGE.md5 did not match, check downloaded package"
1160 fi
1161 fi
1162 else
1163 echo "Toolchain is already downloaded. Exiting..."
1164 fi
1165 ;;
1166 sources-iso)
1167 prepareenv
1168 echo "`date -u '+%b %e %T'`: Build sources iso for $MACHINE" | tee -a $LOGFILE
1169 chroot $LFS /tools/bin/env -i HOME=/root \
1170 TERM=$TERM PS1='\u:\w\$ ' \
1171 PATH=/usr/local/bin:/bin:/usr/bin:/sbin:/usr/sbin \
1172 VERSION=$VERSION NAME="$NAME" SNAME="$SNAME" MACHINE=$MACHINE \
1173 /bin/bash -x -c "cd /usr/src/lfs && make -f sources-iso LFS_BASEDIR=/usr/src install" >>$LOGFILE 2>&1
1174 mv $LFS/install/images/ipfire-* $BASEDIR >> $LOGFILE 2>&1
1175 stdumount
1176 ;;
1177 svn)
1178 case "$2" in
1179 update|up)
1180 # clear
1181 echo -n "Load the latest source files..."
1182 svn update >> $PWD/log/_build.svn.update.log
1183 if [ $? -eq 0 ]; then
1184 echo ".Done!"
1185 else
1186 echo ".Fail!"
1187 exit 1
1188 fi
1189 echo -n "Write the svn info to a file..."
1190 svn info > $PWD/svn_status
1191 if [ "$?" -eq "0" ]; then
1192 echo ".Done!"
1193 else
1194 echo ".Fail!"
1195 exit 1
1196 fi
1197 chmod 755 $0
1198 tail log/_build.svn.update.log
1199 exit 0
1200 ;;
1201 commit|ci)
1202 clear
1203 if [ -e /sbin/yast ]; then
1204 $0 changelog
1205 fi
1206 echo "Upload the changed files..."
1207 sleep 1
1208 IPFIRE_SVN_MESSAGE=/tmp/ipfire-svn-co-message.txt
1209 rm -f $IPFIRE_SVN_MESSAGE
1210 mcedit $IPFIRE_SVN_MESSAGE
1211 svn commit -F $IPFIRE_SVN_MESSAGE
1212 rm -f $IPFIRE_SVN_MESSAGE
1213 $0 svn up
1214 ;;
1215 dist)
1216 #$0 svn up
1217 echo -ne "Download source package from svn..."
1218 svn export http://svn.ipfire.eu/svn/ipfire ipfire-source/ --force > /dev/null
1219 if [ "$?" -eq "0" ]; then
1220 echo ".Done!"
1221 else
1222 echo ".Fail!"
1223 exit 1
1224 fi
1225 echo -n "Compress files..."
1226 tar cfz ipfire-source-r$SVN_REVISION.tar.gz ipfire-source
1227 if [ "$?" -eq "0" ]; then
1228 echo ".Done!"
1229 else
1230 echo ".Fail!"
1231 exit 1
1232 fi
1233 echo -n "Cleanup..."
1234 rm ipfire-source/ -r
1235 if [ "$?" -eq "0" ]; then
1236 echo ".Done!"
1237 else
1238 echo ".Fail!"
1239 exit 1
1240 fi
1241 ;;
1242 diff)
1243 echo -ne "Make a local diff to last svn revision..."
1244 svn diff > ipfire-diff-`date +'%Y-%m-%d-%H:%M'`-r`svn info | grep Revision | cut -c 11-`.diff
1245 if [ "$?" -eq "0" ]; then
1246 echo ".Done!"
1247 else
1248 echo ".Fail!"
1249 exit 1
1250 fi
1251 echo "Diff was successfully saved to ipfire-diff-`date +'%Y-%m-%d-%H:%M'`-r`svn info | grep Revision | cut -c 11-`.diff"
1252 ;;
1253 esac
1254 ;;
1255 make-config)
1256 echo -e "This is for creating your configuration..."
1257 echo -e "We will need some input:"
1258 echo -e ""
1259 echo -n "FTP-DOMAIN FOR THE ISO: "
1260 read IPFIRE_FTP_URL_EXT
1261 echo -n "PATH FOR $IPFIRE_FTP_URL_EXT: "
1262 read IPFIRE_FTP_PATH_EXT
1263 echo -n "USERNAME FOR $IPFIRE_FTP_URL_EXT: "
1264 read IPFIRE_FTP_USER_EXT
1265 echo -n "PASSWORD FOR $IPFIRE_FTP_URL_EXT: "
1266 read -s IPFIRE_FTP_PASS_EXT
1267 echo ""
1268 echo "(You can leave this empty if the cache-server is the same as your iso-server.)"
1269 echo -n "FTP-DOMAIN FOR THE CACHE: "
1270 read IPFIRE_FTP_URL_INT
1271 echo -n "PATH FOR $IPFIRE_FTP_URL_INT: "
1272 read IPFIRE_FTP_PATH_INT
1273 if [ $IPFIRE_FTP_URL_INT ]; then
1274 echo -n "USERNAME FOR $IPFIRE_FTP_URL_INT: "
1275 read IPFIRE_FTP_USER_INT
1276 echo -n "PASSWORD FOR $IPFIRE_FTP_URL_INT: "
1277 read -s IPFIRE_FTP_PASS_INT
1278 else
1279 IPFIRE_FTP_URL_INT=$IPFIRE_FTP_URL_EXT
1280 IPFIRE_FTP_USER_INT=$IPFIRE_FTP_USER_EXT
1281 IPFIRE_FTP_PASS_INT=$IPFIRE_FTP_PASS_EXT
1282 echo "USERNAME FOR $IPFIRE_FTP_URL_INT: $IPFIRE_FTP_USER_INT"
1283 echo "PASSWORD FOR $IPFIRE_FTP_URL_INT: !HIDDEN!"
1284 fi
1285 echo ""
1286 echo "(You can leave this empty if the pak-server is the same as your iso-server.)"
1287 echo -n "FTP-DOMAIN FOR THE PAKS: "
1288 read IPFIRE_FTP_URL_PAK
1289 echo -n "PATH FOR $IPFIRE_FTP_URL_PAK: "
1290 read IPFIRE_FTP_PATH_PAK
1291 if [ $IPFIRE_FTP_URL_PAK ]; then
1292 echo -n "USERNAME FOR $IPFIRE_FTP_URL_PAK: "
1293 read IPFIRE_FTP_USER_PAK
1294 echo -n "PASSWORD FOR $IPFIRE_FTP_URL_PAK: "
1295 read -s IPFIRE_FTP_PASS_PAK
1296 else
1297 IPFIRE_FTP_URL_PAK=$IPFIRE_FTP_URL_EXT
1298 IPFIRE_FTP_USER_PAK=$IPFIRE_FTP_USER_EXT
1299 IPFIRE_FTP_PASS_PAK=$IPFIRE_FTP_PASS_EXT
1300 echo "USERNAME FOR $IPFIRE_FTP_URL_PAK: $IPFIRE_FTP_USER_PAK"
1301 echo "PASSWORD FOR $IPFIRE_FTP_URL_PAK: !HIDDEN!"
1302 fi
1303 echo ""
1304 echo -e "ONE OR MORE EMAIL ADDRESS(ES) TO WHICH THE REPORTS WILL BE SENT"
1305 echo -e "(seperated by comma)"
1306 read IPFIRE_MAIL_REPORT
1307 echo -n "EMAIL FROM: "
1308 read IPFIRE_MAIL_FROM
1309 echo -n "EMAIL SERVER: "
1310 read IPFIRE_MAIL_SERVER
1311 echo -n "LOGIN TO MAIL SERVER: "
1312 read IPFIRE_MAIL_USER
1313 echo -n "MAIL PASSWORD: "
1314 read -s IPFIRE_MAIL_PASS
1315 echo -n "Saving..."
1316 for i in `seq 20`; do
1317 sleep 0.1; echo -n "."
1318 done
1319 echo ".Finished!"
1320 cat <<END > .config
1321 ### ISO server
1322 IPFIRE_FTP_URL_EXT=$IPFIRE_FTP_URL_EXT
1323 IPFIRE_FTP_PATH_EXT=$IPFIRE_FTP_PATH_EXT
1324 IPFIRE_FTP_USER_EXT=$IPFIRE_FTP_USER_EXT
1325 IPFIRE_FTP_PASS_EXT=$IPFIRE_FTP_PASS_EXT
1326 ### cache server
1327 IPFIRE_FTP_URL_INT=$IPFIRE_FTP_URL_INT
1328 IPFIRE_FTP_PATH_INT=$IPFIRE_FTP_PATH_INT
1329 IPFIRE_FTP_USER_INT=$IPFIRE_FTP_USER_INT
1330 IPFIRE_FTP_PASS_INT=$IPFIRE_FTP_PASS_INT
1331 ### paks server
1332 IPFIRE_FTP_URL_PAK=$IPFIRE_FTP_URL_PAK
1333 IPFIRE_FTP_PATH_PAK=$IPFIRE_FTP_PATH_PAK
1334 IPFIRE_FTP_USER_PAK=$IPFIRE_FTP_USER_PAK
1335 IPFIRE_FTP_PASS_PAK=$IPFIRE_FTP_PASS_PAK
1336 ### mail reports
1337 IPFIRE_MAIL_REPORT=$IPFIRE_MAIL_REPORT
1338 IPFIRE_MAIL_FROM=$IPFIRE_MAIL_FROM
1339 IPFIRE_MAIL_SERVER=$IPFIRE_MAIL_SERVER
1340 IPFIRE_MAIL_USER=$IPFIRE_MAIL_USER
1341 IPFIRE_MAIL_PASS=$IPFIRE_MAIL_PASS
1342 END
1343 ;;
1344 sync)
1345 echo -e "Syncing cache to ftp:"
1346 # rm -f doc/packages-to-remove-from-ftp
1347 ncftpls -u $IPFIRE_FTP_USER_INT -p $IPFIRE_FTP_PASS_INT ftp://$IPFIRE_FTP_URL_INT$IPFIRE_FTP_PATH_INT/ > ftplist
1348 for i in `ls -w1 cache/`; do
1349 grep $i ftplist
1350 if [ "$?" -ne "0" ]; then
1351 ncftpput -u $IPFIRE_FTP_USER_INT -p $IPFIRE_FTP_PASS_INT $IPFIRE_FTP_URL_INT $IPFIRE_FTP_PATH_INT/ cache/$i
1352 if [ "$?" -eq "0" ]; then
1353 echo -e "$i was successfully uploaded to the ftp server."
1354 else
1355 echo -e "There was an error while uploading $i to the ftp server."
1356 fi
1357 fi
1358 done
1359 # for i in `cat ftplist`; do
1360 # ls -w1 cache/ | grep $i
1361 # if [ "$?" -eq "1" ]; then
1362 # echo $i | grep -v toolchain >> doc/packages-to-remove-from-ftp
1363 # fi
1364 # done
1365 rm -f ftplist
1366 ;;
1367 upload)
1368 case "$2" in
1369 iso)
1370 echo -e "Uploading the iso to $IPFIRE_FTP_URL_EXT."
1371 cat <<EOF > .ftp-commands
1372 mkdir $IPFIRE_FTP_PATH_EXT
1373 ls -lah
1374 quit
1375 EOF
1376 ncftp -u $IPFIRE_FTP_USER_EXT -p $IPFIRE_FTP_PASS_EXT $IPFIRE_FTP_URL_EXT < .ftp-commands
1377 rm -f .ftp-commands
1378 md5sum ipfire-install-$VERSION.i386.iso > ipfire-install-$VERSION.i386.iso.md5
1379 ncftpput -u $IPFIRE_FTP_USER_EXT -p $IPFIRE_FTP_PASS_EXT $IPFIRE_FTP_URL_EXT $IPFIRE_FTP_PATH_EXT/ ipfire-install-$VERSION.i386.iso
1380 ncftpput -u $IPFIRE_FTP_USER_EXT -p $IPFIRE_FTP_PASS_EXT $IPFIRE_FTP_URL_EXT $IPFIRE_FTP_PATH_EXT/ ipfire-install-$VERSION.i386.iso.md5
1381 ncftpput -u $IPFIRE_FTP_USER_EXT -p $IPFIRE_FTP_PASS_EXT $IPFIRE_FTP_URL_EXT $IPFIRE_FTP_PATH_EXT/ ipfire-source-r$SVN_REVISION.tar.gz
1382 ncftpput -u $IPFIRE_FTP_USER_EXT -p $IPFIRE_FTP_PASS_EXT $IPFIRE_FTP_URL_EXT $IPFIRE_FTP_PATH_EXT/ svn_status
1383 if [ "$?" -eq "0" ]; then
1384 echo -e "The iso of Revision $SVN_REVISION was successfully uploaded to $IPFIRE_FTP_URL_EXT$IPFIRE_FTP_PATH_EXT/."
1385 else
1386 echo -e "There was an error while uploading the iso to the ftp server."
1387 exit 1
1388 fi
1389 if [ "$3" = "--with-sources-cd" ]; then
1390 ncftpput -u $IPFIRE_FTP_USER_EXT -p $IPFIRE_FTP_PASS_EXT $IPFIRE_FTP_URL_EXT $IPFIRE_FTP_PATH_EXT/ ipfire-sources-cd-$VERSION.$MACHINE.iso
1391 fi
1392 ;;
1393 paks)
1394 cat <<EOF > .ftp-commands
1395 mkdir $IPFIRE_FTP_PATH_PAK
1396 ls -lah
1397 quit
1398 EOF
1399 ncftp -u $IPFIRE_FTP_USER_PAK -p $IPFIRE_FTP_PASS_PAK $IPFIRE_FTP_URL_PAK < .ftp-commands
1400 rm -f .ftp-commands
1401 ncftpput -z -u $IPFIRE_FTP_USER_PAK -p $IPFIRE_FTP_PASS_PAK $IPFIRE_FTP_URL_PAK $IPFIRE_FTP_PATH_PAK/ packages/*
1402 if [ "$?" -eq "0" ]; then
1403 echo -e "The packages were successfully uploaded to $IPFIRE_FTP_URL_PAK$IPFIRE_FTP_PATH_PAK/."
1404 else
1405 echo -e "There was an error while uploading the packages to the ftp server."
1406 exit 1
1407 fi
1408 ;;
1409 esac
1410 ;;
1411 build-only)
1412 rm -f $BASEDIR/log/$2*
1413 BUILDMACHINE=`uname -m`
1414 prepareenv
1415 ipcopmake $2
1416 ;;
1417 build-silent)
1418 screen -dmS ipfire $0 build
1419 echo "Build started... This will take a while!"
1420 echo "You can see the status with 'screen -x ipfire'."
1421 ;;
1422 mail)
1423 chmod 755 tools/sendEmail
1424 ATTACHMENT=/tmp/ipfire-build-logs-R$SVN_REVISION.tar.gz
1425 if [ "$2" = "ERROR" ]; then
1426 SUBJECT="ERROR: IPFIRE-BUILD R$SVN_REVISION on `hostname`"
1427 echo "ERROR: $0 build!"
1428 cat <<END > /tmp/ipfire_mail_body
1429 When I was building IPFire on `hostname`, I have found an ERROR!
1430 Here you can see the logs and detect the reason for this error.
1431
1432 Best Regards
1433 Your IPFire-Build-Script
1434 END
1435 fi
1436 if [ "$2" = "SUCCESS" ]; then
1437 SUBJECT="SUCCESS: IPFIRE-BUILD R$SVN_REVISION on `hostname`"
1438 cat <<END > /tmp/ipfire_mail_body
1439 Building IPFire on `hostname` in Revision $SVN_REVISION was successfull!
1440 You can find the ISO on your ftp server.
1441
1442 Statistics:
1443 -----------
1444 Started: $IPFIRE_START_TIME
1445 Finished: `date`
1446
1447 Best Regards
1448 Your IPFire-Build-Script
1449 END
1450 fi
1451 if [ "$2" = "SVNUPDATE" ]; then
1452 SUBJECT="SVNUPDATE: IPFIRE-BUILD R$SVN_REVISION on `hostname`"
1453 echo "ERROR: $0 svn up!"
1454 cat <<END > /tmp/ipfire_mail_body
1455 When I was downloading the latest svn source,
1456 I have found an ERROR!
1457 Here you can see the logs and detect the reason for this error.
1458
1459 Best Regards
1460 Your IPFire-Build-Script
1461 END
1462 fi
1463
1464 if [ "$2" = "SVNDIST" ]; then
1465 SUBJECT="SVNDIST: IPFIRE-BUILD R$SVN_REVISION on `hostname`"
1466 echo "ERROR: $0 svn dist!"
1467 cat <<END > /tmp/ipfire_mail_body
1468 When I was exporting the latest svn source,
1469 I have found an ERROR!
1470 Here you can see the logs and detect the reason for this error.
1471
1472 Best Regards
1473 Your IPFire-Build-Script
1474 END
1475 fi
1476
1477 if [ "$2" = "PREFETCH" ]; then
1478 SUBJECT="PREFETCH: IPFIRE-BUILD R$SVN_REVISION on `hostname`"
1479 echo "ERROR: $0 prefetch!"
1480 cat <<END > /tmp/ipfire_mail_body
1481 When I was downloading the source packages,
1482 I have found an ERROR!
1483 Here you can see the logs and detect the reason for this error.
1484
1485 Best Regards
1486 Your IPFire-Build-Script
1487 END
1488 fi
1489
1490 if [ "$2" = "ISO" ]; then
1491 SUBJECT="ISO: IPFIRE-BUILD R$SVN_REVISION on `hostname`"
1492 echo "ERROR: $0 upload iso!"
1493 cat <<END > /tmp/ipfire_mail_body
1494 When I was uploading the iso image,
1495 I have found an ERROR!
1496 Here you can see the logs and detect the reason for this error.
1497
1498 Best Regards
1499 Your IPFire-Build-Script
1500 END
1501 fi
1502
1503 if [ "$2" = "PAKS" ]; then
1504 SUBJECT="PAKS: IPFIRE-BUILD R$SVN_REVISION on `hostname`"
1505 echo "ERROR: $0 upload paks!"
1506 cat <<END > /tmp/ipfire_mail_body
1507 When I was uploading the packages,
1508 I have found an ERROR!
1509 Here you can see the logs and detect the reason for this error.
1510
1511 Best Regards
1512 Your IPFire-Build-Script
1513 END
1514 fi
1515
1516 tar cfz $ATTACHMENT log/_build*
1517 cat <<END >> /tmp/ipfire_mail_body
1518
1519 Here is a summary... The full logs are in the attachment.
1520 ---------------------------------------------------------
1521
1522 `tail log/_*`
1523 END
1524 cat /tmp/ipfire_mail_body | tools/sendEmail -q \
1525 -f $IPFIRE_MAIL_FROM \
1526 -t $IPFIRE_MAIL_REPORT \
1527 -u $SUBJECT \
1528 -s $IPFIRE_MAIL_SERVER:25 \
1529 -xu $IPFIRE_MAIL_USER \
1530 -xp $IPFIRE_MAIL_PASS \
1531 -l log/_build.mail.log \
1532 -a $ATTACHMENT # -v
1533 rm -f /tmp/ipfire_mail_body $ATTACHMENT
1534 ;;
1535 unattended)
1536 if [ ! -f .config ]; then
1537 echo "No configuration found. Try ./make.sh make-config."
1538 fi
1539 ### This is our procedure that will compile the IPFire by herself...
1540 echo "### UPDATE LOGS"
1541 update_logs
1542
1543 if [ "$IPFIRE_REBUILD" -eq "0" ]; then
1544 echo "### SAVING TIME"
1545 export IPFIRE_START_TIME=`date`
1546
1547 echo "### GETTING TOOLCHAIN"
1548 $0 gettoolchain
1549
1550 echo "### RUNNING SVN-UPDATE"
1551 $0 svn update
1552 if [ $? -ne 0 ]; then
1553 $0 mail SVNUPDATE
1554 exit 1
1555 fi
1556
1557 echo "### EXPORT SOURCES"
1558 $0 svn dist
1559 if [ $? -ne 0 ]; then
1560 $0 mail SVNDIST
1561 exit 1
1562 fi
1563
1564 echo "### RUNNING PREFETCH"
1565 $0 prefetch | grep -q "md5 difference"
1566 if [ $? -eq 0 ]; then
1567 $0 mail PREFETCH
1568 exit 1
1569 fi
1570 fi
1571
1572 echo "### RUNNING BUILD"
1573 $0 build
1574 if [ $? -ne 0 ]; then
1575 $0 mail ERROR
1576 exit 1
1577 fi
1578
1579 echo "### MAKING SOURCES-ISO"
1580 echo "DISABLED by Delaco!"
1581 #$0 sources-iso
1582
1583 echo "### UPLOADING ISO"
1584 $0 upload iso
1585 if [ $? -ne 0 ]; then
1586 $0 mail ISO
1587 exit 1
1588 fi
1589
1590 echo "### UPLOADING PAKS"
1591 $0 upload paks
1592 if [ $? -ne 0 ]; then
1593 $0 mail PAKS
1594 exit 1
1595 fi
1596
1597 echo "### SUCCESS!"
1598 $0 mail SUCCESS
1599 exit 0
1600 ;;
1601 batch)
1602 if [ `screen -ls | grep -q ipfire` ]; then
1603 echo "Build is already running, sorry!"
1604 exit 1
1605 else
1606 if [ "$2" = "--rebuild" ]; then
1607 export IPFIRE_REBUILD=1
1608 echo "REBUILD!"
1609 else
1610 export IPFIRE_REBUILD=0
1611 fi
1612 echo -n "IPFire-Batch-Build is starting..."
1613 screen -dmS ipfire $0 unattended
1614 if [ "$?" -eq "0" ]; then
1615 echo ".Done!"
1616 else
1617 echo ".ERROR!"
1618 exit 1
1619 fi
1620 exit 0
1621 fi
1622 ;;
1623 *)
1624 clear
1625 svn info
1626 select name in "Exit" "IPFIRE: Prefetch" "IPFIRE: Build (silent)" "IPFIRE: Watch Build" "IPFIRE: Batch" "IPFIRE: Clean" "SVN: Commit" "SVN: Update" "SVN: Status" "SVN: Diff" "LOG: Tail" "Help"
1627 do
1628 case $name in
1629 "IPFIRE: Prefetch")
1630 $0 prefetch
1631 ;;
1632 "IPFIRE: Build (silent)")
1633 $0 build-silent
1634 ;;
1635 "IPFIRE: Watch Build")
1636 echo "Exit with Ctrl+A, Ctrl+D."
1637 echo -n "Preparing..."
1638 for i in `seq 10`; do
1639 sleep 0.1; echo -n "."
1640 done
1641 echo ".Ready!"
1642 sleep 0.3
1643 screen -x ipfire
1644 ;;
1645 "IPFIRE: Batch")
1646 $0 batch
1647 ;;
1648 "IPFIRE: Clean")
1649 $0 clean
1650 ;;
1651 "SVN: Commit")
1652 echo "Are your sure to Update all Files to the Server (write: yes)?"; read input
1653 if [ "$input" == "yes" ]; then
1654 $0 svn commit
1655 fi
1656 $0 sync
1657 ;;
1658 "SVN: Update")
1659 $0 svn update
1660 ;;
1661 "SVN: Status")
1662 svn status # | grep -v ^?
1663 ;;
1664 "SVN: Diff")
1665 $0 svn diff
1666 ;;
1667 "Help")
1668 echo "Usage: $0 {build|changelog|check|checkclean|clean|gettoolchain|newpak|prefetch|shell|sync|toolchain}"
1669 cat doc/make.sh-usage
1670 ;;
1671 "LOG: Tail")
1672 tail -f log/_*
1673 ;;
1674 "Exit")
1675 break
1676 ;;
1677 esac
1678 done
1679 ;;
1680 esac