Le GNUmakefile ne devrait plus tout reconstruire sans que les fichiers .txt n’aient changé.

* La somme de contrôle md5 a été retirée.
  * L’ensemble a été testé, mais d’autres tests seraient appréciés
    (après tout, je connais bien moins l’outil que Blanko).
  * Les vérifications de la présence de certains outils ont aussi été
    retirés, car dépréciés en l’absence de somme de contrôle MD5.
This commit is contained in:
Lukc 2012-02-16 12:58:00 +01:00
parent 14ae0546d3
commit 5d4eecd626

View File

@ -37,9 +37,6 @@ PROG_SH = `which sh`
PROG_RM = `which rm` PROG_RM = `which rm`
PROG_FIND = `which find` PROG_FIND = `which find`
PROG_SORT = `which sort` PROG_SORT = `which sort`
PROG_AWK = `which awk`
PROG_MD5SUM = `which md5sum`
PROG_DIFF = `which diff`
PROG_WC = `which wc` PROG_WC = `which wc`
# vérification des programmes # vérification des programmes
@ -70,22 +67,13 @@ endif
ifndef PROG_SORT ifndef PROG_SORT
error_sort = 1 error_sort = 1
endif endif
ifndef PROG_AWK
error_awk = 1
endif
ifndef PROG_MD5SUM
error_md5sum = 1
endif
ifndef PROG_DIFF
error_diff = 1
endif
ifndef PROG_WC ifndef PROG_WC
error_wc = 1 error_wc = 1
endif endif
## DEBUT ## DEBUT
# création de tous les fichiers # création de tous les fichiers
all: test index.html all: test index
# divers tests sur l'existence des dossiers/fichiers # divers tests sur l'existence des dossiers/fichiers
# création si besoin # création si besoin
@ -101,15 +89,7 @@ test:
$(if $(error_rm), @$(PROG_ECHO) -e "\t\trm : MANQUANT." ; exit 1) $(if $(error_rm), @$(PROG_ECHO) -e "\t\trm : MANQUANT." ; exit 1)
$(if $(error_find), @$(PROG_ECHO) -e "\t\tfind : MANQUANT." ; exit 1) $(if $(error_find), @$(PROG_ECHO) -e "\t\tfind : MANQUANT." ; exit 1)
$(if $(error_sort), @$(PROG_ECHO) -e "\t\tsort : MANQUANT." ; exit 1) $(if $(error_sort), @$(PROG_ECHO) -e "\t\tsort : MANQUANT." ; exit 1)
$(if $(error_awk), @$(PROG_ECHO) -e "\t\tawk : MANQUANT." ; exit 1)
$(if $(error_md5sum), @$(PROG_ECHO) -e "\t\tmd5sum : MANQUANT." ; exit 1)
$(if $(error_diff), @$(PROG_ECHO) -e "\t\tdiff : MANQUANT." ; exit 1)
$(if $(error_wc), @$(PROG_ECHO) -e "\t\twc : MANQUANT." ; exit 1) $(if $(error_wc), @$(PROG_ECHO) -e "\t\twc : MANQUANT." ; exit 1)
@$(PROG_ECHO) -e "\t…existence de la somme de contrôle MD5"
@if $(PROG_TEST) -f $(somme_md5); \
then $(PROG_ECHO) -e "\t\t-> OK"; \
else $(PROG_ECHO) -e "\t\t-> manquant"; \
fi
@$(PROG_ECHO) -e "\t…existence des dossiers img, categ et style" @$(PROG_ECHO) -e "\t…existence des dossiers img, categ et style"
@$(PROG_TEST) -d img || mkdir img @$(PROG_TEST) -d img || mkdir img
@$(PROG_TEST) -d $(categ) || mkdir $(categ) @$(PROG_TEST) -d $(categ) || mkdir $(categ)
@ -129,20 +109,14 @@ test:
@$(PROG_ECHO) -e " …terminé." @$(PROG_ECHO) -e " …terminé."
# création du fichier CSS # création du fichier CSS
css: $(dependances_css) $(DESTINATION)/$(CSS_NOM): $(dependances_css)
@$(PROG_ECHO) -e "Création du fichier CSS…" @$(PROG_ECHO) -e "Création du fichier CSS…"
$(if $(MENU), @cp style/$(CSS_AVEC_MENU) $(DESTINATION)/$(CSS_NOM), @cp style/$(CSS_SANS_MENU) $(DESTINATION)/$(CSS_NOM)) $(if $(MENU), @cp style/$(CSS_AVEC_MENU) $(DESTINATION)/$(CSS_NOM), @cp style/$(CSS_SANS_MENU) $(DESTINATION)/$(CSS_NOM))
# @cp style/$(CSS_DEFAUT) $(DESTINATION)/$(CSS_NOM) # @cp style/$(CSS_DEFAUT) $(DESTINATION)/$(CSS_NOM)
@$(PROG_ECHO) -e " …terminée." @$(PROG_ECHO) -e " …terminée."
# vérification de la somme de contrôle des catégories et des éléments, création si besoin
$(somme_md5):
@$(PROG_ECHO) -e "Création d'un fichier 'somme de contrôle' pour l'ensemble des catégories…"
@$(PROG_FIND) ./$(categ) -type f -name *.$(ext) -exec $(PROG_MD5SUM) {} + | $(PROG_AWK) '{print $$1}' | $(PROG_SORT) > $(somme_md5)
@$(PROG_ECHO) -e " …terminée."
# création du fichier $(contenu) # création du fichier $(contenu)
contenu: $(script_contenu) $(somme_md5) $(contenu): $(script_contenu) */*.txt
@$(PROG_SED) -i "s/DEBUG=1/DEBUG=0/g" $(script_contenu) @$(PROG_SED) -i "s/DEBUG=1/DEBUG=0/g" $(script_contenu)
@$(PROG_ECHO) -e "Création du contenu avec les valeurs suivantes : " @$(PROG_ECHO) -e "Création du contenu avec les valeurs suivantes : "
@$(PROG_ECHO) -e "\t\t- Dossier catégorie : $(categ)" @$(PROG_ECHO) -e "\t\t- Dossier catégorie : $(categ)"
@ -155,14 +129,20 @@ contenu: $(script_contenu) $(somme_md5)
@$(PROG_SH) $(script_contenu) $(categ) $(contenu) $(ext) $(composants) $(categ_deb) $(categ_fin) $(elem) @$(PROG_SH) $(script_contenu) $(categ) $(contenu) $(ext) $(composants) $(categ_deb) $(categ_fin) $(elem)
# création de la page d'index # création de la page d'index
index.html: $(DOSSIER_HTML) css contenu $(dependances_index) $(contenu) index: $(INDEX)
$(INDEX): $(DOSSIER_HTML) $(DESTINATION)/$(CSS_NOM) $(dependances_index) $(contenu)
@$(PROG_ECHO) -e "Création de la page de garde…" @$(PROG_ECHO) -e "Création de la page de garde…"
# entete # entete
@$(PROG_ECHO) -e "\t…insertion de l'entête" @$(PROG_ECHO) -e "\t…insertion de l'entête"
@$(PROG_CAT) $(entete) > $(INDEX) @$(PROG_CAT) $(entete) > $(INDEX)
# modification du contenu # modification du contenu
@$(PROG_ECHO) -e "\t…modification du contenu" @$(PROG_ECHO) -e "\t…modification du contenu"
@$(PROG_SED) -i -e "s/@@TITRE_PORTEAIL@@/$(TITRE)/g" -e "s/@@ACCUEIL_PORTEAIL@@/$(ACCUEIL)/g" -e "s#@@CSS_DEFAUT@@#./$(CSS_NOM)#g" -e "s/^\(.*\)@@.*@@\(.*\)$$/\1\2/g" $(INDEX) @$(PROG_SED) -i \
-e "s/@@TITRE_PORTEAIL@@/$(TITRE)/g" \
-e "s/@@ACCUEIL_PORTEAIL@@/$(ACCUEIL)/g" \
-e "s#@@CSS_DEFAUT@@#./$(CSS_NOM)#g" \
-e "s/^\(.*\)@@.*@@\(.*\)$$/\1\2/g" \
$(INDEX)
@$(PROG_ECHO) -e "\t …contenu modifié avec succès !" @$(PROG_ECHO) -e "\t …contenu modifié avec succès !"
# introduction (SI la variable INTRO est remplie) # introduction (SI la variable INTRO est remplie)
$(if $(INTRO), @cat $(INTRO) >> $(INDEX); $(PROG_ECHO) -e "\t…insertion de l'introduction" || exit 1) $(if $(INTRO), @cat $(INTRO) >> $(INDEX); $(PROG_ECHO) -e "\t…insertion de l'introduction" || exit 1)