3 ############################################################################
5 # This file is part of the IPFire Firewall. #
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. #
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. #
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 #
21 # Copyright (C) 2006 IPFire-Team <entwickler@ipfire.org>. #
23 ############################################################################
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
32 MAX_RETRIES
=3 # prefetch/check loop
33 KVER
=`grep --max-count=1 VER lfs/linux | awk '{ print $3 }'`
35 SVN_REVISION
=`svn info | grep Revision | cut -c 11-`
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'`
42 # Debian specific settings
43 if [ ! -e /etc
/debian_version
]; then
46 if [ -x /usr
/bin
/realpath
]; then
47 FULLPATH
=`/usr/bin/realpath $0`
49 echo "ERROR: Need to do apt-get install realpath"
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
62 if [ -f .config
]; then
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
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"
78 echo "`date -u '+%b %e %T'`: Can't determine your architecture - $MACHINE" >> $LOGFILE
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
;
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
106 echo " Check $LOGFILE for errors if applicable"
111 if [ ! -e $BASEDIR/build
/usr
/src
/lfs
/ ]; then
112 exiterror
"No such file or directory: $BASEDIR/build/usr/src/lfs/"
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 \
123 BUILDTARGET
="$BUILDTARGET" MACHINE
="$MACHINE" \
124 KGCC
="ccache /usr/bin/gcc" \
126 if [ $?
-ne 0 ]; then
127 exiterror
"chroot error"
134 ############################################################################
136 # Are we running the right shell? #
138 ############################################################################
139 if [ ! "$BASH" ]; then
140 exiterror
"BASH environment variable is not set. You're probably running the wrong shell."
143 if [ -z "${BASH_VERSION}" ]; then
144 exiterror
"Not running BASH shell."
148 ############################################################################
150 # Trap on emergency exit #
152 ############################################################################
153 trap "exiterror 'Build process interrupted'" SIGINT SIGTERM SIGKILL SIGSTOP SIGQUIT
156 ############################################################################
158 # Resetting our nice level #
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"
167 ############################################################################
169 # Checking if running as root user #
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"
178 ############################################################################
180 # Checking for necessary temporary space #
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"
193 ############################################################################
195 # Building Linux From Scratch system #
197 ############################################################################
198 echo "`date -u '+%b %e %T'`: Building Linux From Scratch system" |
tee -a $LOGFILE
206 # Check /tools symlink
207 if [ -h /tools
]; then
210 if [ ! -a /tools
]; then
211 ln -s $BASEDIR/build
/tools
/
213 if [ ! -h /tools
]; then
214 exiterror
"Could not create /tools symbolic link."
220 export LFS LC_ALL CFLAGS CXXFLAGS
221 unset CC CXX CPP LD_LIBRARY_PATH LD_PRELOAD
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
}
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
241 # Run LFS static binary creation scripts one by one
242 export CCACHE_DIR
=$BASEDIR/ccache
243 export CCACHE_HASHDIR
=1
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
250 ############################################################################
252 # Necessary shell functions #
254 ############################################################################
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"
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"
266 cd $BASEDIR/lfs
&& make -f $
* BUILDTARGET
=$BUILDTARGET \
268 LFS_BASEDIR
=$BASEDIR \
271 install >> $LOGFILE 2>&1
272 if [ $?
-ne 0 ]; then
273 exiterror
"Building $*";
276 exiterror
"No such file or directory: $BASEDIR/$1"
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"
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"
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 \
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 \
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 $*"
308 exiterror
"No such file or directory: $BASEDIR/build/usr/src/lfs/$1"
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"
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"
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 \
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 \
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 $*"
340 exiterror
"No such file or directory: $BASEDIR/build/usr/src/lfs/$1"
346 if [ -f $BASEDIR/build
/usr
/src
/lfs
/$1 ]; then
347 # if [ ! `ls -w1 $BASEDIR/packages/*.tar.gz | 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 \
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 \
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"
365 # echo "`date -u '+%b %e %T'`: Packaging: The package $1 already exists"
368 exiterror
"No such file or directory: $BASEDIR/build/usr/src/lfs/$1"
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"
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"
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 \
389 CONFIG_ROOT
=$CONFIG_ROOT \
391 NAME
="$NAME" SNAME
="$SNAME" SLOGAN
="$SLOGAN" \
392 CFLAGS
="-Os" CXXFLAGS
="-Os" \
393 CCACHE_DIR
=/usr
/src
/ccache CCACHE_HASHDIR
=1 \
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 $*"
402 exiterror
"No such file or directory: $BASEDIR/build/usr/src/lfs/$1"
408 LOGFILE
="$BASEDIR/log/_build.toolchain.log"
410 echo -ne "`date -u '+%b %e %T'`: Stage1 toolchain build \n" |
tee -a $LOGFILE
411 # Build sed now, as we use some extensions
413 NATIVEGCC
=`gcc --version | grep GCC | awk {'print $3'}`
414 export NATIVEGCC GCCmajor
=${NATIVEGCC:0:1} GCCminor=${NATIVEGCC:2:1} GCCrelease=${NATIVEGCC:4:1}
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
429 lfsmake1 gcc LFS_PASS
=2
430 lfsmake1 binutils LFS_PASS
=2
439 lfsmake1
sed LFS_PASS
=2
440 lfsmake1
m4 LFS_PASS
=2
441 lfsmake1 bison LFS_PASS
=2
442 lfsmake1 flex LFS_PASS
=2
451 export PATH
=$ORG_PATH
455 LOGFILE
="$BASEDIR/log/_build.base.log"
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
496 if [ 'i386' = $MACHINE ]; then
498 elif [ 'alpha' = $MACHINE ]; then
517 # Run IPFire make scripts one by one
518 LOGFILE
="$BASEDIR/log/_build.ipfire.log"
520 echo -ne "`date -u '+%b %e %T'`: Stage3 $NAME build \n" |
tee -a $LOGFILE
522 # Build these first as some of the kernel packages below rely on
523 # these for some of their client program functionality
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
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
559 ipcopmake linux LFS_PASS
=ipfire
566 if [ 'i386' = $MACHINE ]; then
567 # These are here because they have i386 only binary libraries
568 # included in the package.
579 ipcopmake promise-sata-300-tx
606 ipcopmake capi4k-utils
611 ipcopmake ez-ipupdate
617 ipcopmake initscripts
624 ipcopmake l7-protocols
625 ipcopmake isapnptools
626 ipcopmake isdn4k-utils
637 ipcopmake HTML-Tagset
638 ipcopmake HTML-Parser
639 ipcopmake Compress-Zlib
641 ipcopmake Digest-SHA1
642 ipcopmake Digest-HMAC
643 ipcopmake libwww-perl
645 ipcopmake Net-IPv4Addr
648 ipcopmake Unix-Syslog
652 ipcopmake Convert-TNEF
653 ipcopmake Convert-UUlib
654 ipcopmake Archive-Tar
655 ipcopmake Archive-Zip
656 ipcopmake Text-Tabs
+Wrap
657 ipcopmake Locale-Country
661 ipcopmake BerkeleyDB
## The Perl module
662 ipcopmake noip_updater
673 ipcopmake saslauthd PASS
=1
676 ipcopmake squid-graph
684 # echo -ne "`date -u '+%b %e %T'`: Building ### IPFire modules ### \n" | tee -a $LOGFILE
686 ipcopmake startscripts
687 ## Zuerst die Libs und dann die Programme. Ordnung muss sein!
699 ipcopmake saslauthd PASS
=2
701 ipcopmake ghostscript
703 # ipcopmake lpd ## Im Moment aus, da CUPS vorhanden ist.
711 ipcopmake bridge-utils
714 ipcopmake smartmontools
717 echo -ne "`date -u '+%b %e %T'`: Building ### Mailserver ### \n" |
tee -a $LOGFILE
726 ipcopmake spamassassin
728 echo -ne "`date -u '+%b %e %T'`: Building ### VoIP-Server ### \n" |
tee -a $LOGFILE
735 echo -ne "`date -u '+%b %e %T'`: Building ### MP3-Server ### \n" |
tee -a $LOGFILE
741 echo -ne "`date -u '+%b %e %T'`: Building ### P2P-Clients ### \n" |
tee -a $LOGFILE
745 # ipcopmake edonkeyclc
747 echo -ne "`date -u '+%b %e %T'`: Building ### Net-Tools ### \n" |
tee -a $LOGFILE
764 # ipcopmake stunnel # Ausgeschaltet, weil wir es doch nicht nutzen
768 # Run installer scripts one by one
769 LOGFILE
="$BASEDIR/log/_build.installer.log"
771 echo -ne "`date -u '+%b %e %T'`: Stage4 installer build \n" |
tee -a $LOGFILE
772 if [ 'i386' = $MACHINE ]; then
780 installmake e2fsprogs
781 installmake misc-progs
783 installmake util-linux
786 installmake pcmcia-cs
788 installmake installer
790 installmake driver.img
796 LOGFILE
="$BASEDIR/log/_build.packages.log"
798 echo "... see detailed log in _build.*.log files" >> $LOGFILE
799 echo -ne "`date -u '+%b %e %T'`: Stage5 packages build \n" |
tee -a $LOGFILE
801 echo "`date -u '+%b %e %T'`: Stripping files" |
tee -a $LOGFILE
802 find $LFS/lib
$LFS/usr
/lib
$LFS/usr
/share
/rrdtool-
* $LFS/install ! -type l \
( -name '*.so' -o -name '*.so[\.0-9]*' \
) \
803 ! -name 'libc.so' ! -name 'libpthread.so' ! -name 'libcrypto.so.0.9.7.sha1' \
804 -exec $LFS/tools
/bin
/strip
--strip-all {} \
; >> $LOGFILE 2>&1
805 # add -ls before -exec if you want to verify what files are stripped
807 find $LFS/{,s
}bin
$LFS/usr
/{,s
}bin
$LFS/usr
/local
/{,s
}bin
! -type l \
808 -exec file {} \
; |
grep " ELF " | cut
-f1 -d ':' |
xargs $LFS/tools
/bin
/strip
--strip-all >> $LOGFILE 2>&1
809 # there add -v to strip to verify
811 if [ 'i386' = $MACHINE ]; then
812 # Create fcdsl packages
813 echo "`date -u '+%b %e %T'`: Building fcdsl tgz" |
tee -a $LOGFILE
814 cp $LFS/install
/images
/fcdsl
/license.txt
$LFS >> $LOGFILE 2>&1
815 touch $LFS/var
/run
/{need-depmod-
$KVER,need-depmod-
$KVER-smp}
816 cd $LFS && tar cvfz
$LFS/install
/images
/$SNAME-fcdsl-$VERSION.
$MACHINE.tgz \
817 lib
/modules
/$KVER/misc
/fcdsl
*.o.gz \
818 lib
/modules
/$KVER-smp/misc
/fcdsl
*.o.gz \
819 usr
/lib
/isdn
/{fds?base.bin
,fd?ubase.frm
} \
820 etc
/fcdsl
/fcdsl
*.conf \
821 etc
/drdsl
/{drdsl
,drdsl.ini
} \
823 var
/run
/{need-depmod-
$KVER,need-depmod-
$KVER-smp} >> $LOGFILE 2>&1
824 rm -f $LFS/license.txt
>> $LOGFILE 2>&1
828 # Generating list of packages used
829 echo "`date -u '+%b %e %T'`: Generating packages list from logs" |
tee -a $LOGFILE
830 rm -f $BASEDIR/doc
/packages-list
831 for i
in `ls -1tr $BASEDIR/log/[^_]*`; do
832 if [ "$i" != "$BASEDIR/log/FILES" -a -n $i ]; then
833 echo " * `basename $i`" >>$BASEDIR/doc
/packages-list
836 echo "====== List of softwares used to build $NAME Version: $VERSION ======" > $BASEDIR/doc
/packages-list.txt
837 grep -v 'configroot$\|img$\|initrd$\|initscripts$\|installer$\|install$\|ipfire$\|setup$\|pakfire$\|stage2$\|smp$\|tools$\|tools1$\|tools2$\|^ipfire-logs' \
838 $BASEDIR/doc
/packages-list |
sort >> $BASEDIR/doc
/packages-list.txt
839 rm -f $BASEDIR/doc
/packages-list
840 # packages-list.txt is ready to be displayed for wiki page
842 # Create ISO for CDRom and USB-superfloppy
844 rm -f $LFS/install
/images
/*usb
*
845 cp $LFS/install
/images
/{*.iso
,*.tgz
} $BASEDIR >> $LOGFILE 2>&1
851 rm -rf $BASEDIR/build
/tmp
/*
853 # Generating total list of files
854 echo "`date -u '+%b %e %T'`: Generating files list from logs" |
tee -a $LOGFILE
855 rm -f $BASEDIR/log
/FILES
856 for i
in `ls -1tr $BASEDIR/log/[^_]*`; do
857 if [ "$i" != "$BASEDIR/log/FILES" -a -n $i ]; then
858 echo "##" >>$BASEDIR/log
/FILES
859 echo "## `basename $i`" >>$BASEDIR/log
/FILES
860 echo "##" >>$BASEDIR/log
/FILES
861 cat $i |
sed "s%^\./%#%" |
sort >> $BASEDIR/log
/FILES
864 cd $BASEDIR/packages
; ls -w1 *.
tar.gz |
awk -F ".tar.gz" '{ print $1 }' > $BASEDIR/packages
/packages_list.txt
865 echo "###EOF###" >> $BASEDIR/packages
/packages_list.txt
872 if [ -d "$BASEDIR/packages" ]; then
873 for i
in `ls $BASEDIR/packages`; do
874 touch $BASEDIR/build
/install
/packages
/$i.empty
878 ipfiredist applejuice
903 ipfiredist spamassassin
904 ipfiredist subversion
905 ipfiredist web-cyradm
908 test -d $BASEDIR/packages || mkdir
$BASEDIR/packages
909 mv -f $LFS/install
/packages
/*.
{tar.gz
,md5
} $BASEDIR/packages
>> $LOGFILE 2>&1
910 rm -rf $BASEDIR/build
/install
/packages
/*
914 tar cfz log
/ipfire-logs-
`date +'%Y-%m-%d-%H:%M'`.tgz log
/_build.
*
918 # See what we're supposed to do
921 BUILDMACHINE
=`uname -m`
922 PACKAGE
=`ls -v -r $BASEDIR/cache/toolchains/$SNAME-$VERSION-toolchain-$BUILDMACHINE.tar.gz 2> /dev/null | head -n 1`
923 #only restore on a clean disk
924 if [ ! -f log
/perl-
*-tools ]; then
925 if [ ! -n "$PACKAGE" ]; then
926 echo "`date -u '+%b %e %T'`: Full toolchain compilation" |
tee -a $LOGFILE
930 PACKAGENAME
=${PACKAGE%.tar.gz}
931 echo "`date -u '+%b %e %T'`: Restore from $PACKAGE" |
tee -a $LOGFILE
932 if [ `md5sum $PACKAGE | awk '{print $1}'` == `cat $PACKAGENAME.md5 | awk '{print $1}'` ]; then
936 exiterror
"$PACKAGENAME md5 did not match, check downloaded package"
940 echo "`date -u '+%b %e %T'`: Using installed toolchain" |
tee -a $LOGFILE
947 # Setzen des IPFire Builds
948 if [ "$FIREBUILD" ]; then
949 echo "$FIREBUILD" > $BASEDIR/build
/var
/ipfire
/firebuild
951 echo "_(OvO)_" > $BASEDIR/build
/var
/ipfire
/firebuild
958 # enter a shell inside LFS chroot
959 # may be used to changed kernel settings
964 echo -n "Loading new Changelog from SVN: "
965 svn log http
://svn.ipfire.eu
/svn
/ipfire
> doc
/ChangeLog
969 echo "Checking sources files availability on the web"
970 if [ ! -d $DIR_CHK ]; then
975 for c
in `seq $MAX_RETRIES`; do
976 if (( FINISHED
==1 )); then
982 if [ -f "$i" -a "$i" != "Config" ]; then
983 make -s -f $i MACHINE
=$MACHINE LFS_BASEDIR
=$BASEDIR ROOT
=$BASEDIR/build \
984 MESSAGE
="$i\t ($c/$MAX_RETRIES)" check
985 if [ $?
-ne 0 ]; then
986 echo "Check : wget error in lfs/$i"
995 echo "Erasing sources files availability tags"
999 for i
in `mount | grep $BASEDIR | sed 's/^.*loop=\(.*\))/\1/'`; do
1000 $LOSETUP -d $i 2>/dev
/null
1002 for i
in `mount | grep $BASEDIR | cut -d " " -f 1`; do
1006 for i
in `seq 0 7`; do
1007 if ( losetup
/dev
/loop
${i} 2>/dev
/null |
grep -q "/install/images" ); then
1008 umount
/dev
/loop
${i} 2>/dev
/null
;
1009 losetup
-d /dev
/loop
${i} 2>/dev
/null
;
1012 rm -rf $BASEDIR/build
1013 rm -rf $BASEDIR/cdrom
1014 rm -rf $BASEDIR/packages
1016 if [ -h /tools
]; then
1021 # create structure for a new package
1022 echo -e "Name of the new package: $2"
1023 if [ ! -f "lfs/$2" ]; then
1024 echo "`date -u '+%b %e %T'`: Creating directory src/paks/$2"
1025 mkdir
-p src
/paks
/$2
1027 echo "`date -u '+%b %e %T'`: Creating files"
1028 cp $BASEDIR/lfs
/postfix
$BASEDIR/lfs
/$2
1031 touch {,un
}install.sh
1033 echo '#!/bin/bash' > install.sh
1034 echo '#' >> install.sh
1035 echo '#################################################################' >> install.sh
1036 echo '# #' >> install.sh
1037 echo '# This file belongs to IPFire Firewall - GPLv2 - www.ipfire.org #' >> install.sh
1038 echo '# #' >> install.sh
1039 echo '#################################################################' >> install.sh
1040 echo '#' >> install.sh
1041 echo '# Extract the files' >> install.sh
1042 echo 'tar xfz files.tgz -C /' >> install.sh
1043 echo 'cp -f ROOTFILES /opt/pakfire/installed/ROOTFILES.$2' >> install.sh
1045 echo '#!/bin/bash' > uninstall.sh
1046 echo '#################################################################' >> uninstall.sh
1047 echo '# #' >> uninstall.sh
1048 echo '# This file belongs to IPFire Firewall - GPLv2 - www.ipfire.org #' >> uninstall.sh
1049 echo '# #' >> uninstall.sh
1050 echo '#################################################################' >> uninstall.sh
1051 echo '#' >> uninstall.sh
1052 echo '# Delete the files' >> uninstall.sh
1053 echo '## Befehl fehlt noch' >> uninstall.sh
1054 echo 'rm -f /opt/pakfire/installed/ROOTFILES.$2' >> uninstall.sh
1055 echo "`date -u '+%b %e %T'`: Adding files to SVN"
1056 cd - && svn add lfs
/$2 && svn add src
/paks
/$2
1058 echo -n "Do you want to remove the folders? [y/n]"
1060 if [ "$REM" == "y" ]; then
1061 echo "Removing the folders..."
1062 svn del src
/paks
/$2 --force
1064 echo "Folders are kept."
1067 echo "$2 already exists"
1072 if [ ! -d $BASEDIR/cache
]; then
1073 mkdir
$BASEDIR/cache
1075 mkdir
-p $BASEDIR/log
1076 echo "`date -u '+%b %e %T'`:Preload all source files" |
tee -a $LOGFILE
1079 for c
in `seq $MAX_RETRIES`; do
1080 if (( FINISHED
==1 )); then
1086 if [ -f "$i" -a "$i" != "Config" ]; then
1087 make -s -f $i LFS_BASEDIR
=$BASEDIR MESSAGE
="$i\t ($c/$MAX_RETRIES)" download
>> $LOGFILE 2>&1
1088 if [ $?
-ne 0 ]; then
1089 echo "Prefetch : wget error in lfs/$i"
1092 if [ $c -eq 1 ]; then
1093 echo "Prefetch : lfs/$i files loaded"
1099 echo "Prefetch : verifying md5sum"
1102 if [ -f "$i" -a "$i" != "Config" ]; then
1103 make -s -f $i LFS_BASEDIR
=$BASEDIR MESSAGE
="$i\t " md5
>> $LOGFILE 2>&1
1104 if [ $?
-ne 0 ]; then
1105 echo "md5 difference in lfs/$i"
1110 if [ $ERROR -eq 0 ]; then
1111 echo "Prefetch : all files md5sum match"
1118 BUILDMACHINE
=`uname -m`
1119 echo "`date -u '+%b %e %T'`: Create toolchain tar.gz for $BUILDMACHINE" |
tee -a $LOGFILE
1120 test -d $BASEDIR/cache
/toolchains || mkdir
$BASEDIR/cache
/toolchains
1121 cd $BASEDIR && tar -zc --exclude='log/_build.*.log' -f cache
/toolchains
/$SNAME-$VERSION-toolchain-$BUILDMACHINE.
tar.gz \
1122 build
/{bin
,etc
,usr
/bin
,usr
/local} \
1123 build
/tools
/{bin
,etc
,*-linux-gnu,include
,lib
,libexec
,sbin
,share
,var
} \
1125 md5sum cache
/toolchains
/$SNAME-$VERSION-toolchain-$BUILDMACHINE.
tar.gz \
1126 > cache
/toolchains
/$SNAME-$VERSION-toolchain-$BUILDMACHINE.md5
1130 BUILDMACHINE
=`uname -m`
1131 # arbitrary name to be updated in case of new toolchain package upload
1132 PACKAGE
=$SNAME-$VERSION-toolchain-$BUILDMACHINE
1133 if [ ! -f $BASEDIR/cache
/toolchains
/$PACKAGE.
tar.gz
]; then
1134 URL_IPFIRE
=`grep URL_IPFIRE lfs/Config | awk '{ print $3 }'`
1135 test -d $BASEDIR/cache
/toolchains || mkdir
$BASEDIR/cache
/toolchains
1136 echo "`date -u '+%b %e %T'`: Load toolchain tar.gz for $BUILDMACHINE" |
tee -a $LOGFILE
1137 cd $BASEDIR/cache
/toolchains
1138 wget
$URL_IPFIRE/toolchains
/$PACKAGE.
tar.gz
$URL_IPFIRE/toolchains
/$PACKAGE.md5
>& /dev
/null
1139 if [ $?
-ne 0 ]; then
1140 echo "`date -u '+%b %e %T'`: error downloading toolchain for $BUILDMACHINE machine" |
tee -a $LOGFILE
1142 if [ "`md5sum $PACKAGE.tar.gz | awk '{print $1}'`" = "`cat $PACKAGE.md5 | awk '{print $1}'`" ]; then
1143 echo "`date -u '+%b %e %T'`: toolchain md5 ok" |
tee -a $LOGFILE
1145 exiterror
"$PACKAGE.md5 did not match, check downloaded package"
1149 echo "Toolchain is already downloaded. Exiting..."
1154 echo "`date -u '+%b %e %T'`: Build sources iso for $MACHINE" |
tee -a $LOGFILE
1155 chroot
$LFS /tools
/bin
/env
-i HOME
=/root \
1156 TERM
=$TERM PS1
='\u:\w\$ ' \
1157 PATH
=/usr
/local
/bin
:/bin
:/usr
/bin
:/sbin
:/usr
/sbin \
1158 VERSION
=$VERSION NAME
="$NAME" SNAME
="$SNAME" MACHINE
=$MACHINE \
1159 /bin
/bash
-x -c "cd /usr/src/lfs && make -f sources-iso LFS_BASEDIR=/usr/src install" >>$LOGFILE 2>&1
1160 mv $LFS/install
/images
/ipfire-
* $BASEDIR >> $LOGFILE 2>&1
1167 echo -n "Load the latest source files..."
1168 svn update
>> $PWD/log
/_build.svn.update.log
1169 if [ $?
-eq 0 ]; then
1175 echo -n "Write the svn info to a file..."
1176 svn info
> $PWD/svn_status
1177 if [ "$?" -eq "0" ]; then
1188 if [ -e /sbin
/yast
]; then
1191 echo "Upload the changed files..."
1193 IPFIRE_SVN_MESSAGE
=/tmp
/ipfire-svn-co-message.txt
1194 rm -f $IPFIRE_SVN_MESSAGE
1195 mcedit
$IPFIRE_SVN_MESSAGE
1196 svn commit
-F $IPFIRE_SVN_MESSAGE
1197 rm -f $IPFIRE_SVN_MESSAGE
1202 echo -ne "Download source package from svn..."
1203 svn
export http
://svn.ipfire.eu
/svn
/ipfire ipfire-source
/ --force > /dev
/null
1204 if [ "$?" -eq "0" ]; then
1210 echo -n "Compress files..."
1211 tar cfz ipfire-source-r
$SVN_REVISION.
tar.gz ipfire-source
1212 if [ "$?" -eq "0" ]; then
1218 echo -n "Cleanup..."
1219 rm ipfire-source
/ -r
1220 if [ "$?" -eq "0" ]; then
1228 echo -ne "Make a local diff to last svn revision..."
1229 svn
diff > ipfire-diff-
`date +'%Y-%m-%d-%H:%M'`-r`svn info | grep Revision | cut -c 11-`.
diff
1230 if [ "$?" -eq "0" ]; then
1236 echo "Diff was successfully saved to ipfire-diff-`date +'%Y-%m-%d-%H:%M'`-r`svn info | grep Revision | cut -c 11-`.diff"
1241 echo -e "This is for creating your configuration..."
1242 echo -e "We will need some input:"
1244 echo -n "FTP-DOMAIN FOR THE ISO: "
1245 read IPFIRE_FTP_URL_EXT
1246 echo -n "PATH FOR $IPFIRE_FTP_URL_EXT: "
1247 read IPFIRE_FTP_PATH_EXT
1248 echo -n "USERNAME FOR $IPFIRE_FTP_URL_EXT: "
1249 read IPFIRE_FTP_USER_EXT
1250 echo -n "PASSWORD FOR $IPFIRE_FTP_URL_EXT: "
1251 read -s IPFIRE_FTP_PASS_EXT
1253 echo "(You can leave this empty if the cache-server is the same as your iso-server.)"
1254 echo -n "FTP-DOMAIN FOR THE CACHE: "
1255 read IPFIRE_FTP_URL_INT
1256 echo -n "PATH FOR $IPFIRE_FTP_URL_INT: "
1257 read IPFIRE_FTP_PATH_INT
1258 if [ $IPFIRE_FTP_URL_INT ]; then
1259 echo -n "USERNAME FOR $IPFIRE_FTP_URL_INT: "
1260 read IPFIRE_FTP_USER_INT
1261 echo -n "PASSWORD FOR $IPFIRE_FTP_URL_INT: "
1262 read -s IPFIRE_FTP_PASS_INT
1264 IPFIRE_FTP_URL_INT
=$IPFIRE_FTP_URL_EXT
1265 IPFIRE_FTP_USER_INT
=$IPFIRE_FTP_USER_EXT
1266 IPFIRE_FTP_PASS_INT
=$IPFIRE_FTP_PASS_EXT
1267 echo "USERNAME FOR $IPFIRE_FTP_URL_INT: $IPFIRE_FTP_USER_INT"
1268 echo "PASSWORD FOR $IPFIRE_FTP_URL_INT: !HIDDEN!"
1271 echo "(You can leave this empty if the pak-server is the same as your iso-server.)"
1272 echo -n "FTP-DOMAIN FOR THE PAKS: "
1273 read IPFIRE_FTP_URL_PAK
1274 echo -n "PATH FOR $IPFIRE_FTP_URL_PAK: "
1275 read IPFIRE_FTP_PATH_PAK
1276 if [ $IPFIRE_FTP_URL_PAK ]; then
1277 echo -n "USERNAME FOR $IPFIRE_FTP_URL_PAK: "
1278 read IPFIRE_FTP_USER_PAK
1279 echo -n "PASSWORD FOR $IPFIRE_FTP_URL_PAK: "
1280 read -s IPFIRE_FTP_PASS_PAK
1282 IPFIRE_FTP_URL_PAK
=$IPFIRE_FTP_URL_EXT
1283 IPFIRE_FTP_USER_PAK
=$IPFIRE_FTP_USER_EXT
1284 IPFIRE_FTP_PASS_PAK
=$IPFIRE_FTP_PASS_EXT
1285 echo "USERNAME FOR $IPFIRE_FTP_URL_PAK: $IPFIRE_FTP_USER_PAK"
1286 echo "PASSWORD FOR $IPFIRE_FTP_URL_PAK: !HIDDEN!"
1289 echo -e "ONE OR MORE EMAIL ADDRESS(ES) TO WHICH THE REPORTS WILL BE SENT"
1290 echo -e "(seperated by comma)"
1291 read IPFIRE_MAIL_REPORT
1292 echo -n "EMAIL FROM: "
1293 read IPFIRE_MAIL_FROM
1294 echo -n "EMAIL SERVER: "
1295 read IPFIRE_MAIL_SERVER
1296 echo -n "LOGIN TO MAIL SERVER: "
1297 read IPFIRE_MAIL_USER
1298 echo -n "MAIL PASSWORD: "
1299 read -s IPFIRE_MAIL_PASS
1301 for i
in `seq 20`; do
1302 sleep 0.1; echo -n "."
1307 IPFIRE_FTP_URL_EXT=$IPFIRE_FTP_URL_EXT
1308 IPFIRE_FTP_PATH_EXT=$IPFIRE_FTP_PATH_EXT
1309 IPFIRE_FTP_USER_EXT=$IPFIRE_FTP_USER_EXT
1310 IPFIRE_FTP_PASS_EXT=$IPFIRE_FTP_PASS_EXT
1312 IPFIRE_FTP_URL_INT=$IPFIRE_FTP_URL_INT
1313 IPFIRE_FTP_PATH_INT=$IPFIRE_FTP_PATH_INT
1314 IPFIRE_FTP_USER_INT=$IPFIRE_FTP_USER_INT
1315 IPFIRE_FTP_PASS_INT=$IPFIRE_FTP_PASS_INT
1317 IPFIRE_FTP_URL_PAK=$IPFIRE_FTP_URL_PAK
1318 IPFIRE_FTP_PATH_PAK=$IPFIRE_FTP_PATH_PAK
1319 IPFIRE_FTP_USER_PAK=$IPFIRE_FTP_USER_PAK
1320 IPFIRE_FTP_PASS_PAK=$IPFIRE_FTP_PASS_PAK
1322 IPFIRE_MAIL_REPORT=$IPFIRE_MAIL_REPORT
1323 IPFIRE_MAIL_FROM=$IPFIRE_MAIL_FROM
1324 IPFIRE_MAIL_SERVER=$IPFIRE_MAIL_SERVER
1325 IPFIRE_MAIL_USER=$IPFIRE_MAIL_USER
1326 IPFIRE_MAIL_PASS=$IPFIRE_MAIL_PASS
1330 echo -e "Syncing cache to ftp:"
1331 # rm -f doc/packages-to-remove-from-ftp
1332 ncftpls
-u $IPFIRE_FTP_USER_INT -p $IPFIRE_FTP_PASS_INT ftp://$IPFIRE_FTP_URL_INT$IPFIRE_FTP_PATH_INT/ > ftplist
1333 for i
in `ls -w1 cache/`; do
1335 if [ "$?" -ne "0" ]; then
1336 ncftpput
-u $IPFIRE_FTP_USER_INT -p $IPFIRE_FTP_PASS_INT $IPFIRE_FTP_URL_INT $IPFIRE_FTP_PATH_INT/ cache
/$i
1337 if [ "$?" -eq "0" ]; then
1338 echo -e "$i was successfully uploaded to the ftp server."
1340 echo -e "There was an error while uploading $i to the ftp server."
1344 # for i in `cat ftplist`; do
1345 # ls -w1 cache/ | grep $i
1346 # if [ "$?" -eq "1" ]; then
1347 # echo $i | grep -v toolchain >> doc/packages-to-remove-from-ftp
1355 echo -e "Uploading the iso to $IPFIRE_FTP_URL_EXT."
1356 cat <<EOF > .ftp-commands
1357 mkdir $IPFIRE_FTP_PATH_EXT
1361 ncftp
-u $IPFIRE_FTP_USER_EXT -p $IPFIRE_FTP_PASS_EXT $IPFIRE_FTP_URL_EXT < .ftp-commands
1363 md5sum ipfire-install-
$VERSION.i386.iso
> ipfire-install-
$VERSION.i386.iso.md5
1364 ncftpput
-u $IPFIRE_FTP_USER_EXT -p $IPFIRE_FTP_PASS_EXT $IPFIRE_FTP_URL_EXT $IPFIRE_FTP_PATH_EXT/ ipfire-install-
$VERSION.i386.iso
1365 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
1366 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
1367 ncftpput
-u $IPFIRE_FTP_USER_EXT -p $IPFIRE_FTP_PASS_EXT $IPFIRE_FTP_URL_EXT $IPFIRE_FTP_PATH_EXT/ svn_status
1368 if [ "$?" -eq "0" ]; then
1369 echo -e "The iso of Revision $SVN_REVISION was successfully uploaded to $IPFIRE_FTP_URL_EXT$IPFIRE_FTP_PATH_EXT/."
1371 echo -e "There was an error while uploading the iso to the ftp server."
1374 if [ "$3" = "--with-sources-cd" ]; then
1375 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
1379 cat <<EOF > .ftp-commands
1380 mkdir $IPFIRE_FTP_PATH_PAK
1384 ncftp
-u $IPFIRE_FTP_USER_PAK -p $IPFIRE_FTP_PASS_PAK $IPFIRE_FTP_URL_PAK < .ftp-commands
1386 ncftpput
-z -u $IPFIRE_FTP_USER_PAK -p $IPFIRE_FTP_PASS_PAK $IPFIRE_FTP_URL_PAK $IPFIRE_FTP_PATH_PAK/ packages
/*
1387 if [ "$?" -eq "0" ]; then
1388 echo -e "The packages were successfully uploaded to $IPFIRE_FTP_URL_PAK$IPFIRE_FTP_PATH_PAK/."
1390 echo -e "There was an error while uploading the packages to the ftp server."
1397 rm -f $BASEDIR/log
/$2*
1398 BUILDMACHINE
=`uname -m`
1403 screen
-dmS ipfire
$0 build
1404 echo "Build started... This will take a while!"
1405 echo "You can see the status with 'screen -x ipfire'."
1408 chmod 755 tools
/sendEmail
1409 ATTACHMENT
=/tmp
/ipfire-build-logs-R
$SVN_REVISION.
tar.gz
1410 if [ "$2" = "ERROR" ]; then
1411 SUBJECT
="ERROR: IPFIRE-BUILD R$SVN_REVISION on `hostname`"
1412 echo "ERROR: $0 build!"
1413 cat <<END > /tmp/ipfire_mail_body
1414 When I was building IPFire on `hostname`, I have found an ERROR!
1415 Here you can see the logs and detect the reason for this error.
1418 Your IPFire-Build-Script
1421 if [ "$2" = "SUCCESS" ]; then
1422 SUBJECT
="SUCCESS: IPFIRE-BUILD R$SVN_REVISION on `hostname`"
1423 cat <<END > /tmp/ipfire_mail_body
1424 Building IPFire on `hostname` in Revision $SVN_REVISION was successfull!
1425 You can find the ISO on your ftp server.
1429 Started: $IPFIRE_START_TIME
1433 Your IPFire-Build-Script
1436 if [ "$2" = "SVNUPDATE" ]; then
1437 SUBJECT
="SVNUPDATE: IPFIRE-BUILD R$SVN_REVISION on `hostname`"
1438 echo "ERROR: $0 svn up!"
1439 cat <<END > /tmp/ipfire_mail_body
1440 When I was downloading the latest svn source,
1441 I have found an ERROR!
1442 Here you can see the logs and detect the reason for this error.
1445 Your IPFire-Build-Script
1449 if [ "$2" = "SVNDIST" ]; then
1450 SUBJECT
="SVNDIST: IPFIRE-BUILD R$SVN_REVISION on `hostname`"
1451 echo "ERROR: $0 svn dist!"
1452 cat <<END > /tmp/ipfire_mail_body
1453 When I was exporting the latest svn source,
1454 I have found an ERROR!
1455 Here you can see the logs and detect the reason for this error.
1458 Your IPFire-Build-Script
1462 if [ "$2" = "PREFETCH" ]; then
1463 SUBJECT
="PREFETCH: IPFIRE-BUILD R$SVN_REVISION on `hostname`"
1464 echo "ERROR: $0 prefetch!"
1465 cat <<END > /tmp/ipfire_mail_body
1466 When I was downloading the source packages,
1467 I have found an ERROR!
1468 Here you can see the logs and detect the reason for this error.
1471 Your IPFire-Build-Script
1475 if [ "$2" = "ISO" ]; then
1476 SUBJECT
="ISO: IPFIRE-BUILD R$SVN_REVISION on `hostname`"
1477 echo "ERROR: $0 upload iso!"
1478 cat <<END > /tmp/ipfire_mail_body
1479 When I was uploading the iso image,
1480 I have found an ERROR!
1481 Here you can see the logs and detect the reason for this error.
1484 Your IPFire-Build-Script
1488 if [ "$2" = "PAKS" ]; then
1489 SUBJECT
="PAKS: IPFIRE-BUILD R$SVN_REVISION on `hostname`"
1490 echo "ERROR: $0 upload paks!"
1491 cat <<END > /tmp/ipfire_mail_body
1492 When I was uploading the packages,
1493 I have found an ERROR!
1494 Here you can see the logs and detect the reason for this error.
1497 Your IPFire-Build-Script
1501 tar cfz
$ATTACHMENT log
/_build
*
1502 cat <<END >> /tmp/ipfire_mail_body
1504 Here is a summary... The full logs are in the attachment.
1505 ---------------------------------------------------------
1509 cat /tmp
/ipfire_mail_body | tools
/sendEmail
-q \
1510 -f $IPFIRE_MAIL_FROM \
1511 -t $IPFIRE_MAIL_REPORT \
1513 -s $IPFIRE_MAIL_SERVER:25 \
1514 -xu $IPFIRE_MAIL_USER \
1515 -xp $IPFIRE_MAIL_PASS \
1516 -l log
/_build.
mail.log \
1518 rm -f /tmp
/ipfire_mail_body
$ATTACHMENT
1521 if [ ! -f .config
]; then
1522 echo "No configuration found. Try ./make.sh make-config."
1524 ### This is our procedure that will compile the IPFire by herself...
1525 echo "### UPDATE LOGS"
1528 if [ "$IPFIRE_REBUILD" -eq "0" ]; then
1529 echo "### SAVING TIME"
1530 export IPFIRE_START_TIME
=`date`
1532 echo "### GETTING TOOLCHAIN"
1535 echo "### RUNNING SVN-UPDATE"
1537 if [ $?
-ne 0 ]; then
1542 echo "### EXPORT SOURCES"
1544 if [ $?
-ne 0 ]; then
1549 echo "### RUNNING PREFETCH"
1550 $0 prefetch |
grep -q "md5 difference"
1551 if [ $?
-eq 0 ]; then
1557 echo "### RUNNING BUILD"
1559 if [ $?
-ne 0 ]; then
1564 echo "### MAKING SOURCES-ISO"
1565 echo "DISABLED by Delaco!"
1568 echo "### UPLOADING ISO"
1570 if [ $?
-ne 0 ]; then
1575 echo "### UPLOADING PAKS"
1577 if [ $?
-ne 0 ]; then
1587 if [ `screen -ls | grep -q ipfire` ]; then
1588 echo "Build is already running, sorry!"
1591 if [ "$2" = "--rebuild" ]; then
1592 export IPFIRE_REBUILD
=1
1595 export IPFIRE_REBUILD
=0
1597 echo -n "IPFire-Batch-Build is starting..."
1598 screen
-dmS ipfire
$0 unattended
1599 if [ "$?" -eq "0" ]; then
1611 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"
1617 "IPFIRE: Build (silent)")
1620 "IPFIRE: Watch Build")
1621 echo "Exit with Ctrl+A, Ctrl+D."
1622 echo -n "Preparing..."
1623 for i
in `seq 10`; do
1624 sleep 0.1; echo -n "."
1637 echo "Are your sure to Update all Files to the Server (write: yes)?"; read input
1638 if [ "$input" == "yes" ]; then
1646 svn status
# | grep -v ^?
1652 echo "Usage: $0 {build|changelog|check|checkclean|clean|gettoolchain|newpak|prefetch|shell|sync|toolchain}"
1653 cat doc
/make.sh-usage