#---------------------------------------------------------------------------- # build_bzip2.txt - how to build the libbz2 binaries and create folder and packages # # Creation : 2008-05-10 holbru # Last update: $Id$ # # !!! this is not a script but an step-by-step howto !!! #------------------------------------------------------------------------------ exit 1 ### download the source code from the internet, e.g. # http:// http://www.bzip.org/downloads.html # libbz2-1.0.5.tar.bz2 ### extract file in a temporary location tar -xjf libbz2-1.0.5.tar.bz2 cd libbz2-1.0.5.tar.bz2 # 2010-09-25 -> libbzip2-1.0.6 # 2012-11-04 -> libbzip2-1.0.6 LibC-2.8 # 2013-06-09 -> libbzip2-1.0.6 GLibC-2.11.3 # 2013-07-29 -> libbzip2-1.0.6 rebuild with ld-2.22 # 2015-03-19 -> libbzip2-1.0.6 rebuild LibC-2.15 # patches from Suse # bzip2-1.0.6-29.2.7.src.rpm # with configure # hbfl # 2017-09-20 -> bzip2-1.0.6 glibc-2.22 # build with rpm Suse # bzip2-1.0.6-32.53.src.rpm # hbfl # 2018-11-11 -> bzip2-1.0.6 # build with rpm Suse # bzip2-1.0.6-43.1.src.rpm # hbfl # 2019-05-31 -> bzip2-1.0.6 # build with rpm Suse # bzip2-1.0.6-44.1.src.rpm # hbfl # 2019-07-24 -> bzip2-1.0.7 # build with rpm Suse # bzip2-1.0.7-1.2.src.rpm # hbfl # 2019-08-18 -> bzip2-1.0.8 # build with rpm Suse # bzip2-1.0.8-1.1.src.rpm # hbfl # 2019-12-16 -> bzip2-1.0.8 # build with rpm Suse # bzip2-1.0.8-2.1.src.rpm # hbfl # 2020-03-31 -> bzip2-1.0.8 # rebuild with rpm Suse -> gcc-9.2.1 -> glibc-2.31 # bzip2-1.0.8-2.2.src.rpm # hbfl # 2021-05-17 -> bzip2-1.0.8 # rebuild with rpm Suse -> gcc-10 -> glibc-2.33 # bzip2-1.0.8-2.22.src.rpm # hbfl # 2023-03-24 -> bzip2-1.0.8 # rebuild with rpm Suse -> gcc-12 -> glibc-2.37 # bzip2-1.0.8-5.4.src.rpm # hbfl # 2025-03-10 -> bzip2-1.0.8 # rebuild with rpm Suse -> gcc-14 -> glibc-2.41 # bzip2-1.0.8-5.11.src.rpm ### build export CFLAGS='-O2 -march=i486' export CXXFLAGS="${CFLAGS}" # to build shared lib use '-f Makefile-libbz2_so' instead # zum relativ linken sed -i 's@\(ln -s -f \)$(PREFIX)/bin/@\1@' Makefile make -f Makefile-libbz2_so make install PREFIX=/public/lib/bzip2/1.0.6/usr # install shared binarie cp -v bzip2-shared /public/utils/bzip2/1.0.6/usr/bin/bzip2 cp -av libbz2.so* /public/utils/bzip2/1.0.6/usr/lib cd /public/utils/bzip2/1.0.6/usr/lib ln -sfv libbz2.so.1.0 libbz2.so cd /public/utils/bzip2/1.0.6/usr rm -v {bunzip2,bzcat} ln -sfv bzip2 bunzip2 ln -sfv bzip2 bzcat # strip files/binarys for filename in `find /public/lib/bzip2/1.0.6/usr/{bin/*,lib/*.so.*} -type f` do echo $filename strip -R .note -R .comment "$filename" done cd /usr/bin cp -f bzip2 bunzip2 cp -f bzip2 bzcat ln -sf bzgrep bzegrep ln -sf bzgrep bzfgrep ln -sf bzmore bzless ln -sf bzdiff bzcmp # copy files cp *** /lib/libbz2/bin_**_libbz2_1_0_5/*** #--------------------------------------------------------------------------- create folder Um die Folder im Hauptverszeichnis zu erstellen gibt es das Script 'libbz2-folder.sh' unter libbz2/_ADMIN/ mit libbz2-folder.sh -v 1.0.5 -w create wird die folder Struktur fuer die lib Version 1.0.5 erstellt nun koennen die files aus dem compilat eingefuegt werden. mit libbz2-folder.sh -v 1.0.5 -w add wird ein svn add auf die erzeugten Folder durchgefuehrt. mit libbz2-folder.sh -v 1.0.5 -w list wird fuer jeden Folder die files-list.txt erzeugt, add muss zwingend vorher ausgefuehrt worden sein mit libbz2-folder.sh -v 1.0.5 -w ci erfolgt der commit der erzeugten Folder In den eis und eis_dev Foldern muessen keine Anpassungen vorgenommen werden. Diese Anpassungen erfolgen beim packen der packages durch mktarball.sh mit den _do_ Scripten unter _ADMIN automatisch. In den Pack-Scripten unter _ADMIN muss dann noch die Pfadangabe geaendert werden, auf den soeben erzeugten Pfad und ein commit ausgefuehrt werden. Nach dem checkout auf eisler koennen nun die packages erzeugt werden. die wichtigsten Parameter fuer mktarball.sh sind dann -setdate now -setversion ${version} mktarball.sh - home -setdate now -setversion [version angeben] libbz2 libbz2-dev duch die Angabe von -home werden die packages in die Folder Struktur /home/user/public_html/packages/ kopiert und koennen von da direkt auf Pack-Eis geladen werden. wichtig ist noch, dass unbedingt die 'lib' Version zuerst gebaut werden muss, da fuer die 'dev' Version Informationen aus der 'lib' Info Datei gelesen werden.