#---------------------------------------------------------------------------- # build_at.txt - how to build the at binaries and create folder and packages # # Creation : 2010-02-13 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. # search debian for at # at-3.1.10.2.tar.bz2 ### extract file in a temporary location tar -xzvf at-3.1.10.2.tar.gz cd at-3.1.10.2 # 2010-06-19 -> at-3.1.12 # 2013-03-16 -> at-3.1.13 # 2013-09-17 -> at-3.1.13-4.3 # Buld with RPM Suse Factory # at-3.1.13-4.3.src.rpm # 2014-11-04 -> at-3.1.15 # build with rpm Suse 13.1 # at-3.1.15-1225.3.src.rpm # 2014-11-14 -> at-3.1.16 # build with rpm based on Suse # at-3.1.16-2225.5.src.rpm # 2016-03-19 -> at-3.1.16 # rebuild with rpm suse # at-3.1.16-1233.7.src.rpm # hbfl # 2018-03-10 -> at-3.1.20 # build with rpm Suse # at-3.1.20-1237.103.src.rpm # hbfl # 2018-03-31 -> at-3.1.20 # rebuild with rpm Suse, without Posixtimer.patch # at-3.1.20-7.103.src.rpm # hbfl # 2019-11-17 -> at-3.1.23 # build with rpm Suse # at-3.1.23-2.1.src.rpm # hbfl # 2020-08-26 -> at-3.1.23 # rebuild with rpm Suse -> gcc-9 -> glibc-2.3 # at-3.1.23-3.4.src.rpm # switch to group and user 'at' # hbfl # 2021-07-04 -> at-3.2.1 # build with rpm Suse -> gcc-10-> glibc-2.33 # at-3.2.1-2.1.src.rpm # hbfl # 2022-01-11 -> at-3.2.2 # build with rpm Suse # at-3.2.2-4.2.src.rpm # build without Posixtimer.patch!!!!!!!!!!!!!!!!!!!!! # hbfl # 2022-11-20 -> at-3.2.5 # build with rpm Suse # at-3.2.5-1.3.src.rpm # switch to /var/spool/atjobs # use posixtimer now, included upstream # build with systemd # hbfl # 2023-05-11 -> at-3.2.5 # rebuild with rpm Suse -> gcc-12 -> glibc-2.37 # at-3.2.5-2.2.src.rpm # switch pam to /usr/lib/pam.d # hbfl # 2025-04-24 -> at-3.2.5 # rebuild with rpm Suse -> gcc-14 -> glibc-2.41 # at-3.2.5-3.2.src.rpm require -> libhx-dev require -> pam-dev touch /usr/sbin/sendmail chmod 755 /usr/sbin/sendmail ### build export CFLAGS='-O2 -march=i486' export CXXFLAGS="${CFLAGS}" ./configure --prefix=/usr \ --build=i486-pc-linux-gnu \ --host=i486-pc-linux-gnu make make test make IROOT=/public/utils/at/3.1.13 install # strip files/binarys for filename in `find /public/utils/at/3.1.13/usr/{bin/*,sbin/*} -type f` do echo $filename strip -R .note -R .comment "$filename" done # copy files cp *** /lib/at/bin_**_at_3_1_10_2/*** at_bin="atrm atq" cd /usr/bin for _fname in ${at_bin} do rm -f ${_fname} ln -sf at ${_fname} done if [ ! -f /var/spool/cron/atjobs/.SEQ ] then echo 0 > /var/spool/cron/atjobs/.SEQ fi if [ ! -f /var/spool/cron/atspool/.SEQ ] then echo 0 > /var/spool/cron/atspool/.SEQ fi chown daemon:daemon /var/spool/cron/at{jobs,spool}/.SEQ chmod 600 /var/spool/cron/at{jobs,spool}/.SEQ chown daemon:daemon /var/spool/cron/at{jobs,spool} chmod 1770 /var/spool/cron/at{jobs,spool} if [ ! -f /etc/at.deny ] then touch /etc/at.deny fi if [ ! -f /etc/at.allow ] then touch /etc/at.deny fi chown root:daemon /etc/at.{deny,allow} chmod 0640 /etc/at.{deny,allow} chown daemon:daemon /usr/bin/at chmod 6555 /usr/bin/at #--------------------------------------------------------------------------- create folder Um die Folder im Hauptverszeichnis zu erstellen gibt es das Script 'at-folder.sh' unter at/_ADMIN/ mit at-folder.sh -v 3.1.10.2 -w create wird die folder Struktur fuer die lib Version 3.1.10.2 erstellt nun koennen die files aus dem compilat eingefuegt werden. mit at-folder.sh -v 3.1.10.2 -w add wird ein svn add auf die erzeugten Folder durchgefuehrt. mit at-folder.sh -v 3.1.10.2 -w list wird fuer jeden Folder die files-list.txt erzeugt, add muss zwingend vorher ausgefuehrt worden sein mit at-folder.sh -v 3.1.10.2 -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] at at-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.