"stable"-Releases koennen jetzt NICHT mehr erstellt werden - es war nicht wartbar
nun ist der Export wesentlich sauberer
This commit is contained in:
parent
00e71d1085
commit
1914cfbe65
1 changed files with 60 additions and 68 deletions
130
Makefile
130
Makefile
|
@ -1,64 +1,72 @@
|
||||||
########## Variablendefinitionen ###########
|
########## Variablendefinitionen ###########
|
||||||
|
|
||||||
# Revision-Variablen
|
# Revision-Variablen
|
||||||
STABLE_REVISION := 143
|
REVISIONS_NR := $(shell svn -R info| grep ^Revision| cut -f2 -d " " | sort | tail -1)
|
||||||
AKTUELLE_REVISION := $(shell svn -R info| grep ^Revision| cut -f2 -d " " | sort | tail -1)
|
REVISIONS_SUFFIX = _r$(REVISIONS_NR)
|
||||||
REVISIONS_SUFFIX = -r$(ARBEITS_REVISION)
|
REVISIONS_DATUM = $(shell svn log -r $(REVISIONS_NR) -q | grep -v "^---" | cut -d "|" -f 3)
|
||||||
REVISIONS_DATUM = $(shell svn log -r $(ARBEITS_REVISION) -q | grep -v "^---" | cut -d "|" -f 3)
|
REPOSITORY_URL = https://svn.systemausfall.org/svn/cryptocd/trunk
|
||||||
|
|
||||||
# Verzeichnisse
|
# Verzeichnisse
|
||||||
ROOT_DIR := $(shell pwd)
|
ROOT_DIR := $(shell pwd)
|
||||||
EXPORT_DIR = $(ROOT_DIR)/export
|
|
||||||
|
# hierhin sollten lokale Verzeichnisse verlinkt werden
|
||||||
EXT_DIR = $(ROOT_DIR)/extern
|
EXT_DIR = $(ROOT_DIR)/extern
|
||||||
EXT_DIR_PROGS = $(EXT_DIR)/programme
|
EXT_DIR_PROGS = $(EXT_DIR)/programme
|
||||||
EXT_DIR_CHAOSRADIO = $(EXT_DIR)/chaosradio
|
EXT_DIR_CHAOSRADIO = $(EXT_DIR)/chaosradio
|
||||||
# der Name der export-Archive
|
|
||||||
|
# Ablage der erstellten zip/iso-Dateien
|
||||||
|
EXPORT_DIR = $(ROOT_DIR)/export
|
||||||
|
# so beginnt das export-Verzeichnis
|
||||||
EXPORT_PREFIX := cryptocd
|
EXPORT_PREFIX := cryptocd
|
||||||
|
# wird an das export-Verzeichnis angehaengt - nur fuer "release" und "release_all" wichtig
|
||||||
|
EXPORT_FILE_SUFFIX := undefiniert
|
||||||
|
EXPORT_FILE = $(EXPORT_DIR)/$(EXPORT_PREFIX)$(REVISIONS_SUFFIX)$(EXPORT_FILE_SUFFIX)
|
||||||
|
|
||||||
|
# Zwischenlagerung
|
||||||
TMP_ROOT = $(ROOT_DIR)/tmp
|
TMP_ROOT = $(ROOT_DIR)/tmp
|
||||||
CCD_BUILD_DIR = $(TMP_ROOT)/$(EXPORT_PREFIX)$(REVISIONS_SUFFIX)
|
CCD_BUILD_DIR = $(TMP_ROOT)/$(EXPORT_PREFIX)$(REVISIONS_SUFFIX)
|
||||||
EXPORT_FILE = $(EXPORT_DIR)/$(EXPORT_PREFIX)$(REVISIONS_SUFFIX)$(EXPORT_FILE_SUFFIX)
|
|
||||||
|
# Verzeichnisse, die vorhanden sein muessen
|
||||||
ERROR_DIRS = $(TMP_ROOT) $(EXT_DIR) $(EXPORT_DIR) $(EXT_DIR_PROGS)
|
ERROR_DIRS = $(TMP_ROOT) $(EXT_DIR) $(EXPORT_DIR) $(EXT_DIR_PROGS)
|
||||||
|
# Verzeichnisse, die vorhanden sein sollten
|
||||||
WARNING_DIRS = $(EXT_DIR_CHAOSRADIO)
|
WARNING_DIRS = $(EXT_DIR_CHAOSRADIO)
|
||||||
|
|
||||||
# Aktionen
|
# Aktionen
|
||||||
ERZEUGE_MIRROR = _scripts/erzeuge_export_mirror.sh $(MIRROR_QUELLE_DIR) $(CCD_BUILD_DIR)
|
|
||||||
ERZEUGE_TAR = tar cjhf $(EXPORT_FILE).tar.bz2 -C $(dir $(CCD_BUILD_DIR)) $(notdir $(CCD_BUILD_DIR))
|
ERZEUGE_TAR = tar cjhf $(EXPORT_FILE).tar.bz2 -C $(dir $(CCD_BUILD_DIR)) $(notdir $(CCD_BUILD_DIR))
|
||||||
ERZEUGE_ZIP = cd $(dir $(CCD_BUILD_DIR)); zip -9qr $(EXPORT_FILE).zip $(notdir $(CCD_BUILD_DIR))
|
ERZEUGE_ZIP = cd $(dir $(CCD_BUILD_DIR)); zip -9qr $(EXPORT_FILE).zip $(notdir $(CCD_BUILD_DIR))
|
||||||
ERZEUGE_ISO = mkisofs $(ISO_OPTS) -o $(EXPORT_FILE).iso $(CCD_BUILD_DIR) 2>&1 | $(EINRUECKEN)
|
ERZEUGE_ISO = mkisofs $(ISO_OPTS) -o $(EXPORT_FILE).iso $(CCD_BUILD_DIR) 2>&1 | $(EINRUECKEN)
|
||||||
|
|
||||||
# Sonstiges
|
# Sonstiges
|
||||||
|
# Optionen fuer mkisofs
|
||||||
ISO_OPTS = -iso-level 3 -J -joliet-long -relaxed-filenames -f -r -V $(EXPORT_PREFIX)$(REVISIONS_SUFFIX)
|
ISO_OPTS = -iso-level 3 -J -joliet-long -relaxed-filenames -f -r -V $(EXPORT_PREFIX)$(REVISIONS_SUFFIX)
|
||||||
|
# Ausgabe-Filter zum Einruecken
|
||||||
EINRUECKEN = sed 's/^/\t/'
|
EINRUECKEN = sed 's/^/\t/'
|
||||||
|
# Voreinstellung - wird nur fuer "make website" ueberschrieben
|
||||||
# Voreinstellungen
|
|
||||||
ARBEITS_REVISION = $(AKTUELLE_REVISION)
|
|
||||||
LINE_STATUS = offline
|
LINE_STATUS = offline
|
||||||
EXPORT_FILE_SUFFIX := undefiniert
|
|
||||||
# gilt nur fuer "release" und "release_all"
|
|
||||||
|
|
||||||
####### Variablen, die vererbt werden sollen ###########
|
####### Variablen, die vererbt werden sollen ###########
|
||||||
export CCD_BUILD_DIR
|
export CCD_BUILD_DIR
|
||||||
|
|
||||||
####### Allgemeine targets ###########
|
########### Allgemeine targets ###########
|
||||||
|
|
||||||
.PHONY : clean all documents check help website website-stable release release-stable source source-stable export-all cd-template release_all release_all-stable setze_releaseinfos hole_svn_export svn_erzeuge_links verlinke_programme verlinke_chaosradio cd-template
|
.PHONY : clean all documents check help website release release_big source export cd-template setze_releaseinfos verlinke_programme verlinke_chaosradio
|
||||||
|
|
||||||
|
# nur ein Alias - damit doku das default-target ist (das erste im Makefile)
|
||||||
all: doku
|
all: doku
|
||||||
|
|
||||||
help:
|
help:
|
||||||
@echo "allgemeine Targets:"
|
@echo "allgemeine Targets:"
|
||||||
@echo " help - diese Uebersicht"
|
@echo " help - diese Uebersicht"
|
||||||
@echo " doku - das Doku-Verzeichnis erneuern"
|
@echo " doku - das Doku-Verzeichnis erneuern"
|
||||||
@echo " all - dasselbe wie 'doku'"
|
|
||||||
@echo " clean - unnoetige Dateien loeschen"
|
@echo " clean - unnoetige Dateien loeschen"
|
||||||
@echo " check - Pruefung der Links"
|
@echo " check - Pruefung der Links"
|
||||||
@echo
|
@echo
|
||||||
@echo "Export-Targets:"
|
@echo "Export-Targets:"
|
||||||
@echo " source[-stable] - die lyx-Quellen und Bilder"
|
@echo " source - die lyx-Quellen und Bilder"
|
||||||
@echo " release[-stable] - alles ausser Chaosradio"
|
@echo " release - alles ausser Chaosradio"
|
||||||
@echo " release_all[-stable] - mit Chaosradio-Dateien"
|
@echo " release_big - mit Chaosradio-Dateien"
|
||||||
@echo " website[-stable] - fuer die Webseite: mit Programmen, ohne Chaosradio"
|
@echo " website - fuer die Webseite: mit Programmen, ohne Chaosradio"
|
||||||
@echo " export-all - erstellt alle Export-Formen (auch stable)"
|
@echo " export - erstellt alle Export-Formen"
|
||||||
|
|
||||||
clean:
|
clean:
|
||||||
@echo $(ICH)
|
@echo $(ICH)
|
||||||
|
@ -69,6 +77,7 @@ check:
|
||||||
make -C doku
|
make -C doku
|
||||||
linkchecker -r 3 --intern='!^mailto:' --extern-strict-all start.html
|
linkchecker -r 3 --intern='!^mailto:' --extern-strict-all start.html
|
||||||
|
|
||||||
|
# pruefe, ob alle notwendigen/empfohlenen Verzeichnisse existieren
|
||||||
verzeichnisstruktur: $(ERROR_DIRS) $(WARNING_DIRS)
|
verzeichnisstruktur: $(ERROR_DIRS) $(WARNING_DIRS)
|
||||||
|
|
||||||
$(ERROR_DIRS):
|
$(ERROR_DIRS):
|
||||||
|
@ -80,16 +89,6 @@ $(ERROR_DIRS):
|
||||||
$(WARNING_DIRS):
|
$(WARNING_DIRS):
|
||||||
@[ ! -e "$@" ] && echo -e "directory ($@) does not exist - it is recommended\n\tyou could create a symlink or make this directory\n"
|
@[ ! -e "$@" ] && echo -e "directory ($@) does not exist - it is recommended\n\tyou could create a symlink or make this directory\n"
|
||||||
|
|
||||||
####### speziell fuer die stable-targets ###########
|
|
||||||
|
|
||||||
%-stable: ARBEITS_REVISION := $(STABLE_REVISION)
|
|
||||||
%-stable: MIRROR_QUELLE_DIR = $(TMP_ROOT)/svn-$(EXPORT_PREFIX)$(REVISIONS_SUFFIX)
|
|
||||||
website: LINE_STATUS=online
|
|
||||||
|
|
||||||
release-stable: release
|
|
||||||
release_all-stable: release_all
|
|
||||||
source-stable: source
|
|
||||||
website-stable: website
|
|
||||||
|
|
||||||
######## die Werkzeuge #########
|
######## die Werkzeuge #########
|
||||||
|
|
||||||
|
@ -98,43 +97,43 @@ cd-template: verzeichnisstruktur
|
||||||
@cp --remove-destination -r cd-template $(CCD_BUILD_DIR)
|
@cp --remove-destination -r cd-template $(CCD_BUILD_DIR)
|
||||||
@rm -rf `find $(CCD_BUILD_DIR) -type d -name ".svn"`
|
@rm -rf `find $(CCD_BUILD_DIR) -type d -name ".svn"`
|
||||||
|
|
||||||
|
|
||||||
doku: cd-template
|
doku: cd-template
|
||||||
@echo "Aktualisiere das Doku-Verzeichnis ..."
|
@echo "Aktualisiere das Doku-Verzeichnis ..."
|
||||||
# aufgrund einer Seltsamkeit im doku-Makefile, muss es zweimal aufgerufen werden,
|
# aufgrund einer Seltsamkeit im doku-Makefile, muss es zweimal aufgerufen werden,
|
||||||
# wenn der online- zum offline-Status geaendert wird (und umgekehrt)
|
# wenn der online- zum offline-Status geaendert wird (und umgekehrt)
|
||||||
|
# die Dateien werden erst beim zweiten Durchlauf gebaut
|
||||||
@make -C documents $(LINE_STATUS)
|
@make -C documents $(LINE_STATUS)
|
||||||
|
@make -C documents $(LINE_STATUS)
|
||||||
|
# Kopieren der Dateien ins das Abbild-Verzeichnis
|
||||||
@make -C documents install
|
@make -C documents install
|
||||||
|
|
||||||
setze_releaseinfos: cd-template
|
|
||||||
# ein nutzloses Relikt, oder nur der falsche Dateiname?
|
|
||||||
# @echo "Passe version.txt an ..."
|
|
||||||
# sed -i 's/REVISIONS_PLATZHALTER/$(ARBEITS_REVISION)/g; s/DATUMS_PLATZHALTER/$(REVISIONS_DATUM)/g' $(CCD_BUILD_DIR)/version.txt
|
|
||||||
|
|
||||||
hole_quell_daten:
|
setze_releaseinfos: cd-template
|
||||||
@if [ ! -e "$(MIRROR_QUELLE_DIR)" ] ;\
|
# ein nutzloses Relikt, oder nur der falsche Dateiname?
|
||||||
then mkdir -p $(shell dirname "$(MIRROR_QUELLE_DIR)") ;\
|
# @echo "Passe version.txt an ..."
|
||||||
echo "Exportiere die gewaehlte svn-Revision ($(ARBEITS_REVISION)) ..." ;\
|
# sed -i 's/REVISIONS_PLATZHALTER/$(AKTUELLE_REVISION)/g; s/DATUMS_PLATZHALTER/$(REVISIONS_DATUM)/g' $(CCD_BUILD_DIR)/version.txt
|
||||||
svn export -r $(ARBEITS_REVISION) . "$(MIRROR_QUELLE_DIR)" | $(EINRUECKEN) ;\
|
|
||||||
else echo "Verwende existierende lokale svn-Kopie" ;\
|
|
||||||
fi
|
|
||||||
|
|
||||||
verlinke_programme: cd-template
|
verlinke_programme: cd-template
|
||||||
@echo "Erzeuge Links zu den Programmen ..."
|
@echo "Erzeuge Links zu den Programmen ..."
|
||||||
@ln -s "$(EXT_DIR_PROGS)" "$(CCD_BUILD_DIR)/programme"
|
@ln -s "$(EXT_DIR_PROGS)" "$(CCD_BUILD_DIR)/programme"
|
||||||
|
|
||||||
|
|
||||||
verlinke_chaosradio: cd-template
|
verlinke_chaosradio: cd-template
|
||||||
@echo "Erzeuge Links zu den ChaosRadio-Dateien ..."
|
@echo "Erzeuge Links zu den ChaosRadio-Dateien ..."
|
||||||
@if [ -e "$(EXT_DIR_CHAOSRADIO)" ]; \
|
@if [ -e "$(EXT_DIR_CHAOSRADIO)" ]; \
|
||||||
then ln -s "$(CCD_BUILD_DIR)/ausLese/chaosradio" "$(CCD_BUILD_DIR)/ausLese" ; \
|
then ln -s "$(EXT_DIR_CHAOSRADIO)" "$(CCD_BUILD_DIR)/ausLese/chaosradio" ; \
|
||||||
else echo "Warnung: keine ChaosRadio-Dateien gefunden ($(ROOT_DIR)/ausLese/chaosradio) - ignoriert" >&2 ; \
|
else echo "keine ChaosRadio-Dateien gefunden ($(EXT_DIR_CHAOSRADIO))" >&2 ; \
|
||||||
|
false ;\
|
||||||
fi
|
fi
|
||||||
|
|
||||||
####### die Ausgabe-Formate ###########
|
####### die Ausgabe-Formate ###########
|
||||||
|
|
||||||
|
website: LINE_STATUS=online
|
||||||
website: EXPORT_FILE_SUFFIX := _website
|
website: EXPORT_FILE_SUFFIX := _website
|
||||||
website: cd-template verlinke_programme
|
website: cd-template verlinke_programme
|
||||||
@echo "Gruppen-Schreibrecht setzen (fuer eduforge) ..."
|
@echo "Gruppen-Schreibrecht setzen (fuer eduforge) ..."
|
||||||
@# fuer die Zugriffsrechte auf dem eduforge-Server
|
|
||||||
@chmod -R g+rw $(TMP_ROOT)
|
@chmod -R g+rw $(TMP_ROOT)
|
||||||
|
|
||||||
@echo "Erzeuge Archiv der online-Dateien ..."
|
@echo "Erzeuge Archiv der online-Dateien ..."
|
||||||
|
@ -142,18 +141,23 @@ website: cd-template verlinke_programme
|
||||||
|
|
||||||
|
|
||||||
source: EXPORT_FILE_SUFFIX := _src
|
source: EXPORT_FILE_SUFFIX := _src
|
||||||
source: CCD_BUILD_DIR = $(MIRROR_QUELLE_DIR)
|
source: CCD_BUILD_DIR := $(CCD_BUILD_DIR)$(EXPORT_FILE_SUFFIX)
|
||||||
source: hole_quell_daten
|
source:
|
||||||
|
@if [ ! -e "$(CCD_BUILD_DIR)" ] ;\
|
||||||
|
then echo "Exportiere die gewaehlte svn-Revision ($(REVISIONS_NR)) ..." ;\
|
||||||
|
svn export -r $(REVISIONS_NR) "$(REPOSITORY_URL)" "$(CCD_BUILD_DIR)" | $(EINRUECKEN) ;\
|
||||||
|
else echo "Verwende existierende lokale svn-Kopie" ;\
|
||||||
|
fi
|
||||||
@echo "Erzeuge source-Archiv ..."
|
@echo "Erzeuge source-Archiv ..."
|
||||||
@$(ERZEUGE_TAR)
|
@$(ERZEUGE_TAR)
|
||||||
|
|
||||||
|
|
||||||
release: EXPORT_FILE_SUFFIX := _small
|
release: EXPORT_FILE_SUFFIX := _small
|
||||||
|
|
||||||
release_all: EXPORT_FILE_SUFFIX := _all
|
release_big: EXPORT_FILE_SUFFIX := _all
|
||||||
release_all: verlinke_chaosradio verlinke_programme
|
release_big: verlinke_chaosradio
|
||||||
|
|
||||||
release release_all: doku verlinke_programme setze_releaseinfos
|
release release_big: doku verlinke_programme setze_releaseinfos
|
||||||
@echo "Erzeuge zip-Archiv ..."
|
@echo "Erzeuge zip-Archiv ..."
|
||||||
@$(ERZEUGE_ZIP)
|
@$(ERZEUGE_ZIP)
|
||||||
@echo "Erzeuge iso-Image ..."
|
@echo "Erzeuge iso-Image ..."
|
||||||
|
@ -161,27 +165,15 @@ release release_all: doku verlinke_programme setze_releaseinfos
|
||||||
|
|
||||||
|
|
||||||
export-all:
|
export-all:
|
||||||
@echo "Erstelle website ..."
|
@echo "Erstelle die Web-Seite ..."
|
||||||
@make website
|
@make website
|
||||||
|
|
||||||
#make website-stable
|
@echo "Erstelle kleine Release-Pakete ..."
|
||||||
# klappt nicht wegen des restriktiven diffs
|
|
||||||
|
|
||||||
@echo "Erstelle aktuelles Quell-Paket ... "
|
|
||||||
@make source
|
|
||||||
|
|
||||||
@echo "Erstelle stabiles Quell-Paket ..."
|
|
||||||
@make source-stable
|
|
||||||
|
|
||||||
@echo "Erstelle kleine aktuelle Release-Pakete ..."
|
|
||||||
@make release
|
@make release
|
||||||
|
|
||||||
@echo "Erstelle kleine stabile Release-Pakete ..."
|
@echo "Erstelle grosse Release-Pakete ..."
|
||||||
@make release-stable
|
|
||||||
|
|
||||||
@echo "Erstelle grosse aktuelle Release-Pakete ..."
|
|
||||||
@make release_all
|
@make release_all
|
||||||
|
|
||||||
@echo "Erstelle grosse stabile Release-Pakete ..."
|
@echo "Erstelle das Quell-Paket ... "
|
||||||
@make release_all-stable
|
@make source
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue