36cbf44bbc
git-svn-id: svn://svn.compuextreme.de/Viitor/V962/ViitorMake@4393 504e572c-2e33-0410-9681-be2bf7408885
116 lines
4.6 KiB
Bash
116 lines
4.6 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: libdv
|
|
#Quelle der Source Archive: www.freshmeat.net
|
|
#Kurzbeschreibung:
|
|
#Video Format decode für das DV Format (wird von Digital Video
|
|
#kammeras verwendet)
|
|
#
|
|
#Letzte Änderung von: $Author$
|
|
#Datum der letzten Änderung: $Date$
|
|
#Version der Datei: $Revision$
|
|
#
|
|
#
|
|
|
|
#Pfad zum Basis-Sourcetree eintragen !
|
|
SRCPATH=X11/MultiMedia
|
|
|
|
#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() {
|
|
echo "Nothing to do for premk"
|
|
}
|
|
|
|
mk32() {
|
|
CC="gcc $BUILDOPTIONS32" \
|
|
CXX="g++ $BUILDOPTIONS32" \
|
|
LDFLAGS="-L/usr/lib -L/usr/X11R7/lib" \
|
|
./configure --target=$TARGET32 \
|
|
--host=$TARGET32 \
|
|
--build=$TARGET32 \
|
|
--prefix=/usr &&
|
|
make -j $NUMCPU &&
|
|
make -j $NUMCPU DESTDIR=$TMPROOT install
|
|
make distclean
|
|
ClearHostSysNameing32 $TMPROOT
|
|
}
|
|
|
|
#Hier wird der Make Prozess der Sourcen definiert
|
|
mk() {
|
|
if [ "$MK64BIT" == "true" ]; then
|
|
ADDOPTIONS="--libdir=\${prefix}/lib64"
|
|
export LDFLAGS="-L/usr/lib64 -L/usr/X11R7/lib64"
|
|
fi
|
|
CC="gcc $BUILDOPTIONS" \
|
|
CXX="g++ $BUILDOPTIONS" \
|
|
./configure --target=$TARGET \
|
|
$ADDOPTIONS \
|
|
--prefix=/usr &&
|
|
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() {
|
|
ClearHostSysNameing $TMPROOT
|
|
}
|