#----------------------------------------------------------------------------
# build_pwgen.txt - how to build the pwgen binaries and create folder and packages
#
# Creation   : 2015-10-19 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://        pwgen

# pwgen-2.07.tar.bz2

### extract file in a temporary location
tar -xf pwgen-2.07.tar.bz2

# 2015-10-19 -> pwgen-2.07
# build with rpm Suse
# pwgen-2.07-195.3.src.rpm

# 2015-02-17 -> pwgen-2.07
# build with rpm suse
# pwgen-2.07-195.6.src.rpm
# patch drop "'" in symbols 

# hbfl
# 2018-03-29 -> pwgen-2.08
# build with rpm Suse
# pwgen-2.08-1.1.src.rpm 
# patch drop "'" in symbols

# hbfl
# 2020-06-09 -> pwgen-2.08
# build with rpm Suse
# pwgen-2.08-1.8.src.rpm
# patch drop "'" in symbols

# hbfl
# 2021-09-06 -> pwgen-2.08
# rebuild with rpm Suse -> gcc-10 -> glibc-2.33
# pwgen-2.08-1.13.src.rpm
# pwgen-colon.patch  drop "'" in symbols

# hbfl
# 2023-05-19 -> pwgen-2.08
# rebuild with rpm Suse -> gcc-12 -> glibc-2.37
# pwgen-2.08-2.5.src.rpm
# pwgen-colon.patch  drop "'" in symbols

cd pwgen-2.07

### build

export CFLAGS='-O2 -march=i486'
export CXXFLAGS="${CFLAGS}"


./configure  \
--prefix=/usr  \
--build=i486-pc-linux-gnu  \
--host=i486-pc-linux-gnu

make
make check
make DESTDIR=/public/pwgen install

# strip files/binarys
for filename in `find /public/pwgen/usr/{bin/*,lib/*.so.*} -type f`
do
    echo $filename
    strip -R .note -R .comment "$filename"
done

# copy files
cp *** <svn-root>/lib/pwgen/bin_**_pwgen_2_07/***


#----------------------------------------------------------------------------

create folder

Um die Folder im Hauptverszeichnis zu erstellen gibt es das Script 'pwgen-folder.sh'
unter pwgen/_ADMIN/

mit
pwgen-folder.sh -v 2.07 -w create

    wird die folder Struktur fuer die lib Version 2.07 erstellt

    nun koennen die files aus dem compilat eingefuegt werden.

mit
pwgen-folder.sh -v 2.07 -w add

    wird ein svn add auf die erzeugten Folder durchgefuehrt.

mit
pwgen-folder.sh -v 2.07 -w list

    wird fuer jeden Folder die files-list.txt erzeugt, add muss zwingend
    vorher ausgefuehrt worden sein

mit
pwgen-folder.sh -v 2.07 -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] pwgen pwgen-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.