#---------------------------------------------------------------------------- # build_libgd.txt - how to build the libgd binaries and create folder and packages # # Creation : 2012-11-28 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://www.libgd.org/ # https://bitbucket.org/libgd/gd-libgd/downloads # libgd-2.0.36.tar.bz2 ### extract file in a temporary location tar -xjvf libgd-2.0.36.tar.bz2 cd libgd-2.0.36 Patches from SuSE Patch2: gd-format.patch Patch3: gd-aliasing.patch Patch6: gd-fontpath.patch Patch7: gd-2.0.36RC1-config.patch Patch8: gd-2.0.36.RC1-ppc64.patch Patch9: gd-png_check_sig.patch # 2013-07-06 libdg-2.1.0 LibC-2.11.3 # 2015-04-15 -> gd-2.1.1 # build with rpm Suse # gd-2.1.1-1.1.src.rpm # 2016-06-24 -> gd-2.1.1 # rebuild with rpm Suse # gd-2.1.1-4.2.src.rpm # link in pkgconfig erzeugen ** Configuration summary for libgd 2.1.1: Support for Zlib: yes Support for PNG library: yes Support for JPEG library: yes Support for VPX library: yes Support for TIFF library: yes Support for Freetype 2.x library: yes Support for Fontconfig library: yes Support for Xpm library: no Support for pthreads: yes # hbfl # 2018-01-22 -> gd-2.2.5 # buid with rpm Suse # gd-2.2.5-1.2.src.rpm # hbfl # 2018-09-15 -> gd-2.2.5 # buid with rpm Suse # gd-2.2.5-3.1.src.rpm # hbfl # 2019-05-15 -> gd-2.2.5 # buid with rpm Suse # gd-2.2.5-5.1.src.rpm # hbfl # 2019-12-20 -> gd-2.2.5 # buid with rpm Suse # gd-2.2.5-7.1.src.rpm # hbfl # 2020-03-10 -> gd-2.2.5 # buid with rpm Suse # gd-2.2.5-8.1.src.rpm # hbfl # 2020-04-04 -> gd-2.2.5 # rebuid with rpm Suse -> gcc-9.2.1 -> glibc-2.31 # gd-2.2.5-8.1.src.rpm # gd-2.2.5-8.1.2.src.rpm -> fontconfig # 2020-05-10 # gd-2.2.5-8.1.3.src.rpm -> xpm # hbfl # 2021-06-11 -> gd-2.3.2 # buid with rpm Suse -> gcc-10 -> glibc-2.33 # gd-2.3.2-1.2.src.rpm # hbfl # 2023-04-26 -> gd-2.3.3 # buid with rpm Suse -> gcc-12 -> glibc-2.37 # gd-2.3.3-3.2.src.rpm ### build export CFLAGS='-O2 -march=i486' export CXXFLAGS="${CFLAGS}" ./configure \ --prefix=/usr \ --build=i486-pc-linux-gnu \ --host=i486-pc-linux-gnu ** Configuration summary for gd 2.0.36: Support for PNG library: yes Support for JPEG library: yes Support for Freetype 2.x library: yes Support for Fontconfig library: yes Support for Xpm library: no Support for pthreads: yes ** Configuration summary for libgd 2.1.0: Support for Zlib: yes Support for PNG library: yes Support for JPEG library: yes Support for VPX library: yes Support for TIFF library: yes Support for Freetype 2.x library: yes Support for Fontconfig library: yes Support for Xpm library: no Support for pthreads: yes make https://bitbucket.org/libgd/gd-libgd/issue/72/gdimagestringft_bbox-test-fails-on-old export XFAIL_TESTS=gdimagestringft/gdimagestringft_bbox make check make DESTDIR=/public/lib/gd/2.1.0 install # strip files/binarys for filename in `find /public/lib/gd/2.1.0/usr/{bin/*,lib/*.so.*} -type f` do echo $filename strip -R .note -R .comment "$filename" done # copy files cp *** /lib/libgd/bin_**_libgd_2_0_36/*** #---------------------------------------------------------------------------- create folder Um die Folder im Hauptverszeichnis zu erstellen gibt es das Script 'libgd-folder.sh' unter libgd/_ADMIN/ mit libgd-folder.sh -v 2.0.36 -w create wird die folder Struktur fuer die lib Version 2.0.36 erstellt nun koennen die files aus dem compilat eingefuegt werden. mit libgd-folder.sh -v 2.0.36 -w add wird ein svn add auf die erzeugten Folder durchgefuehrt. mit libgd-folder.sh -v 2.0.36 -w list wird fuer jeden Folder die files-list.txt erzeugt, add muss zwingend vorher ausgefuehrt worden sein mit libgd-folder.sh -v 2.0.36 -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] libgd libgd-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.