ViitorMake/SysBuild/DebugModules/libmcal
kueller e4ea1f71fc Neue Version V963
git-svn-id: svn://svn.compuextreme.de/Viitor/V963/ViitorMake@5933 504e572c-2e33-0410-9681-be2bf7408885
2011-01-03 10:48:06 +00:00

158 lines
5.7 KiB
Bash

#!/bin/bash
#Framework, welches ein komplettes Linux System aus den Sourcen erstellt
#dieses Framework wird im CVS Repository
#:pserver:cvs.tramp-bbs.de:/opt/cvs zur Verfügung gestellt
#
#Lage dieser Datei im Archiv: $HeadURL$
#
#(c) 2003 Harald Kueller, Germany
#This program is free software; you can redistribute it and/or
#modify ist under the terms of the GNU General Public License
#as published by the Free Software Foundation; either version
#2 of the License, or (at your option) any later version.
#
#This program is distributed in the hope that it will be useful,
#but WITHOUT ANY WARRANTY; without even the implied warranty of
#MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
#See the GNU General Public License for more details.
#
#You should have received a copy of the GNU General Public License
#along with this program; if not write to the Free Software Foundation,
#Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
#
#Dies ist ein Module zur Verwendung mit genpkg. Die Erzeugung eines
#Viitor Linux Packetes wird über die Funktionen premk, mk und postmk
#gesteuert. premk() dient zur Vorbereitung des Sourcecodes. Hier können
#diverse Änderungen am sourcecode (mit awk/sed usw.) vorgenommen werden
#mk() umfasst die source Konfiguration und das Übersetzten des source
#codes. Auch die Installation muß von mk erledigt werden. Hier gild dass
#die Installation immer nach $TMPROOT erfolgen soll (meisst kann das mit
#"make DESTDIR=$TMPROOT install" angestossen werden). postmk kann
#vor der packeterstellung noch einiges am installationtree ändern. postmk
#läuft nachdem die Packetabhängigkeiten erstellt wurden.
#Das Verhalten von genpkg kann über die Variable MKPKG gesteuert werden.
#Hier müssen FLAGS zur Steuerung gesetzt werden. Folgende Flags werden
#erkannt:
#
# 1 : Package Erzeugung erzwingen. Packet wird, auch wenn es schon
# vorhanden ist, ohne weitere rückfragen neu Erzeugt.
# 2 : Package Installation erzwingen. Installpkg wird mit -f aufgerufen.
# Das bewirkt, das installpkg keine rückfragen bei der installation
# Stellt, und das packet in jedemfall (neu) installiert.
# 4 : Sourcepacket nicht nach MAKEDIR entpacken. Ist dieses Flag gesetzt
# muss sich das Module selber um das Entpacken der sourcedateien kümmern.
# vor allem wichtig bei Packeten, für die es keine source.tgz gibt
# (z.B. aus dem CVS generierte Packete).
# 8 : Erstellung des Packetes aus $TMPROOT wird unterdrückt. Dies ist bei
# manchen Sonderfällen möglich - wenn sich z.B. der Packetnamen nicht
# aus dem Namen des sourcearchives ableiten lässt. Packet sollte in
# so einem Fall in der postmk() Funktion erstellt werden.
# 16 : Packet wird nicht installiert. Bei Packeten wie tar oder bash kann
# die installation mittelst installpkg probleme machen.
# 32 : Dependics File so erzeugen, das die Abhängigkeiten bei der installation
# erfüllt sein müssen. installpkg bricht in so einem fall bei fehlenden
# packeten die installation ab, und gibt nicht "nur" warnmeldungen aus.
# Wichtig bei packeten mit postinstallroutine, die software aus dem
# frisch installierten Packet verwendet (wie z.B. postgresql)
# 64 : sourcetree aufräumen nach packeterstellung unterbinden.
#
#Module zur Erstellung des Packetes: libmcal
#Quelle der Source Archive: http://download.sourceforge.net/libmcal
#Kurzbeschreibung:
#Calender access suport Funktionen
#
#Letzte Änderung von: $Author$
#Datum der letzten Änderung: $Date$
#Version der Datei: $Revision$
#
#
#Pfad zu Basis Source Tree eintragen!
SRCPATH=X11/lib
#Funktion wird nach dem Entpacken der Sourcen, im Tree der Sourcen
#ausgeführt (sprich unpack src; cd src; premk)
#Hier kann z.B. das Makefile gepatcht werden (SED lässt grüssen
premk() {
if [ ! -f "$SOURCE/$SRCPATH/mcaldriver*" ]; then
tar -xzvf $SOURCE/$SRCPATH/mcaldriver*
else
echo "Die mcaldrivers* in Tools/lib werden benötigt !"
exit
fi
mv mcal-drivers/{icap,mstore} .
}
mk32() {
cd icap
sed -e "s/ld /ld -melf32_i386 /" Makefile >Makefile.32
make -f Makefile.32 CC="gcc $BUILDOPTIONS32" LDFLAGS="-m32" &&
cd ../mstore
sed -e "s/ld /ld -melf32_i386 /" Makefile >Makefile.32
make -f Makefile.32 CC="gcc $BUILDOPTIONS32" LDFLAGS="-m32" &&
cd ..
chmod 777 *
CC="gcc $BUILDOPTIONS32" \
./configure --target=$TARGET32 \
--prefix=/usr \
--with-icap \
--with-mstore &&
sed -e "s%/usr/local/mcal%$TMPROOT/usr%g" Makefile >Makefile.tmp
sed -e "s/gcc/gcc -m32/g" Makefile.tmp >Makefile
ed icalscanner.lex >/dev/null 2>&1 <<PP
/#include "icalroutines.h"
a
#define INITIAL 0
.
w
PP
make -j $NUMCPU
make -j $NUMCPU DESTDIR=$TMPROOT install
make distclean
sed -e "s/gcc -m32/gcc/g" Makefile >Makefile.tmp
mv Makefile.tmp Makefile
}
#Hier wird der Make Prozess der Sourcen definiert
mk() {
if [ "$MK64BIT" == "true" ]; then
ADDOPTIONS="--libdir=/usr/lib64"
cd icap
make clean
cd ../mstore
make clean
cd ..
mv $TMPROOT/usr/lib $TMPROOT/usr/lib32
fi
cd icap
make CC="gcc $BUILDOPTIONS -fPIC"
cd ../mstore
make CC="gcc $BUILDOPITONS -fPIC"
cd ..
chmod 777 *
CC="gcc $BUILDOPTIONS" \
./configure --target=$TARGET \
--prefix=/usr \
$ADDOPTIONS \
--with-icap \
--with-mstore &&
sed -e "s%/usr/local/mcal%$TMPROOT/usr%g" Makefile >Makefile.tmp
sed -e "s%gcc%gcc -fPIC%g" Makefile.tmp >Makefile
make -j $NUMCPU &&
make -j $NUMCPU DESTDIR=$TMPROOT install
}
#Funktion wird nach Ablauf des Make Prozesses ausgeführt, und kann
#in $TMPROOT noch einiges korrigieren
postmk() {
cp icap/icap.h $TMPROOT/usr/include
cp mstore/mstore.h $TMPROOT/usr/include
cp cal_misc.h $TMPROOT/usr/include
cp icalroutines.h $TMPROOT/usr/include
if [ "$MK64BIT" == "true" ]; then
mv $TMPROOT/usr/lib $TMPROOT/usr/lib64
mv $TMPROOT/usr/lib32 $TMPROOT/usr/lib
fi
}