[MODIF] Transformation creation_categ.sh (BASH) en creation_categ.sh

(SH)
This commit is contained in:
Olivier DOSSMANN 2012-02-09 17:54:19 +01:00
parent dc87a258ba
commit eeb36cdf7a
3 changed files with 55 additions and 48 deletions

View File

@ -33,7 +33,7 @@ PROG_TEST = `which test`
PROG_SED = `which sed` PROG_SED = `which sed`
PROG_CAT = `which cat` PROG_CAT = `which cat`
PROG_CP = `which cp` PROG_CP = `which cp`
PROG_BASH = `which bash` PROG_SH = `which sh`
PROG_RM = `which rm` PROG_RM = `which rm`
## DEBUT ## DEBUT
@ -72,7 +72,7 @@ css: $(dependances_css)
# création du fichier $(contenu) # création du fichier $(contenu)
contenu: $(script_contenu) contenu: $(script_contenu)
@$(PROG_SED) -i "s/DEBUG=1/DEBUG=0/g" $(script_contenu) @$(PROG_SED) -i "s/DEBUG=1/DEBUG=0/g" $(script_contenu)
@$(PROG_BASH) $(script_contenu) || exit @$(PROG_SH) $(script_contenu) || exit
# création de la page d'index # création de la page d'index
index.html: $(DOSSIER_HTML) css contenu $(dependances_index) $(contenu) index.html: $(DOSSIER_HTML) css contenu $(dependances_index) $(contenu)

2
LISMOI
View File

@ -55,7 +55,7 @@ Le programme requièrt les programmes suivants :
- GNU make - GNU make
- cp - cp
- sed - sed
- bash - sh
- echo - echo
- test - test
- cat - cat

View File

@ -1,4 +1,4 @@
#!/usr/bin/env bash #!/usr/bin/env sh
# #
# creation_categ.sh # creation_categ.sh
# #
@ -45,24 +45,25 @@ elem="${dossier_composants}/element.html"
extension="txt" # Extension des fichiers à prendre en compte extension="txt" # Extension des fichiers à prendre en compte
## FONCTIONS ## FONCTIONS
debug() { debug( )
if [[ $DEBUG -eq 1 ]] {
if [ "$DEBUG" -eq 1 ]
then then
echo -e $1 printf "$1\n" 1>&2
fi fi
} }
## TESTS ## TESTS
if ! test -d $dossier if ! test -d "$dossier"
then then
echo -e "Dossier '$dossier' manquant." echo "Dossier '$dossier' manquant."
exit 0 exit 0
fi fi
# On supprime le fichier ${destination} s'il existe. # On supprime le fichier ${destination} s'il existe.
if test -f $destination if test -f "$destination"
then then
echo -e "Le fichier '${destination}' existe : Suppression de ce dernier." echo "Le fichier '${destination}' existe : Suppression de ce dernier."
rm -f $destination rm -f "$destination"
fi fi
## DEBUT ## DEBUT
@ -81,28 +82,28 @@ do
#+ d'une Catégorie #+ d'une Catégorie
CATEG=0 CATEG=0
# On met/remet le tableau des elements à 0 # On met/remet le tableau des elements à 0
elements_titre=() elements_titre=""
elements_url=() elements_url=""
elements_desc=() elements_desc=""
elements_image_addr=() elements_image_addr=""
elements_image_titre=() elements_image_titre=""
elements_image_desc=() elements_image_desc=""
curseur_element=0 curseur_element=0
# Calcul du nombre de ligne du fichier # Calcul du nombre de ligne du fichier
nbre_lignes=`cat ${fichier} |wc -l` nbre_lignes=`cat "${fichier}" |wc -l`
# debug # debug
debug "$fichier: $nbre_lignes" debug "$fichier: $nbre_lignes"
# Vérification du nombre de lignes retourné # Vérification du nombre de lignes retourné
if [[ $nbre_lignes -gt 0 ]] if [ "$nbre_lignes" -gt 0 ]
then then
# Récupération du nom de la catégorie # Récupération du nom de la catégorie
nbre_categories=`grep -E "^\[\[.*\]\].*$" ${fichier} |wc -l` nbre_categories=`grep -E "^\[\[.*\]\].*$" ${fichier} |wc -l`
# Si le nombre de catégorie est égal à 1, on a tout bon # Si le nombre de catégorie est égal à 1, on a tout bon
if [[ $nbre_categories -eq 0 ]] if [ "$nbre_categories" -eq 0 ]
then then
echo "Fichier '${fichier}' mal renseigné : Pas de nom de catégorie" echo "Fichier '${fichier}' mal renseigné : Pas de nom de catégorie"
continue continue
elif [[ $nbre_categories -gt 1 ]] elif [ "$nbre_categories" -gt 1 ]
then then
echo "Fichier '${fichier}' mal renseigné : Trop de catégorie présentes." echo "Fichier '${fichier}' mal renseigné : Trop de catégorie présentes."
continue continue
@ -110,28 +111,28 @@ do
echo "Fichier '${fichier}' correct : Catégorie présente." echo "Fichier '${fichier}' correct : Catégorie présente."
fi fi
# le fichier contient plusieurs lignes, on lit le contenu # le fichier contient plusieurs lignes, on lit le contenu
for ligne in $(cat ${fichier}) for ligne in $(cat "${fichier}")
do do
debug "Contenu ligne : $ligne" debug "Contenu ligne : $ligne"
# Vérifie les différents cas possibles : # Vérifie les différents cas possibles :
#+ SI la chaîne débute par '#' #+ SI la chaîne débute par '#'
#+ exemple : # quelque chose #+ exemple : # quelque chose
diese_comp=`echo $ligne |sed -e 's@^\(#\).*$@\1@g'` diese_comp=`echo "$ligne" |sed -e 's@^\(#\).*$@\1@g'`
debug "Comparaison dièse : $diese_comp" debug "Comparaison dièse : $diese_comp"
if [[ $diese_comp == "#" ]] if [ "$diese_comp" = '#' ]
then then
debug "La ligne est un commentaire : Aucune action." debug "La ligne est un commentaire : Aucune action."
continue continue
fi fi
#+ SI la chaîne commence par '[[' et fini par ']]' #+ SI la chaîne commence par '[[' et fini par ']]'
#+ exemple : [[Titre]]Description de ma catégorie #+ exemple : [[Titre]]Description de ma catégorie
categ_comp=`echo $ligne |sed -e 's#^\(\[\[\).*\(\]\]\).*$#\1\2#g'` categ_comp=`echo "$ligne" |sed -e 's#^\(\[\[\).*\(\]\]\).*$#\1\2#g'`
debug "Comparaison '[[]]' : $categ_comp" debug "Comparaison '[[]]' : $categ_comp"
if [[ $categ_comp == "[[]]" ]] if [ "$categ_comp" = "[[]]" ]
then then
debug "La ligne est une catégorie : Enregistrement." debug "La ligne est une catégorie : Enregistrement."
categ_titre=`echo $ligne |sed -e 's#^\[\[\(.*\)\]\].*$#\1#g'` categ_titre=`echo "$ligne" |sed -e 's#^\[\[\(.*\)\]\].*$#\1#g'`
categ_desc=`echo $ligne |sed -e 's#^\[\[.*\]\]\(.*\)$#\1#g'` categ_desc=`echo "$ligne" |sed -e 's#^\[\[.*\]\]\(.*\)$#\1#g'`
debug "$categ_titre : $categ_desc" debug "$categ_titre : $categ_desc"
CATEG=1 CATEG=1
fi fi
@ -139,7 +140,7 @@ do
#+ exemple : Vous êtes perdus ?##http://perdu.com##Se rendre sur le site perdu.com####Mon image##Description de mon image #+ exemple : Vous êtes perdus ?##http://perdu.com##Se rendre sur le site perdu.com####Mon image##Description de mon image
element_comp=`echo $ligne |sed -e 's@^.*\(##\).*\(##\).*\(##\).*\(##\).*\(##\).*$@\1\2\3\4\5@g'` element_comp=`echo $ligne |sed -e 's@^.*\(##\).*\(##\).*\(##\).*\(##\).*\(##\).*$@\1\2\3\4\5@g'`
debug "Comparaison element : $element_comp" debug "Comparaison element : $element_comp"
if [[ $element_comp == "##########" ]] if [ "$element_comp" = "##########" ]
then then
debug "La ligne est un élément : Enregistrement." debug "La ligne est un élément : Enregistrement."
# Recherche des informations pour l'élément # Recherche des informations pour l'élément
@ -151,24 +152,24 @@ do
element_img_desc=`echo $ligne |sed -e 's@^.*##.*##.*##.*##.*##\(.*\)$@\1@g'` element_img_desc=`echo $ligne |sed -e 's@^.*##.*##.*##.*##.*##\(.*\)$@\1@g'`
debug "Élément : titre=$element_titre, url=$element_url, desc=$element_desc, adresse_image=$element_img_addr, titre_image=$element_img_titre, desc_image=$element_img_desc" debug "Élément : titre=$element_titre, url=$element_url, desc=$element_desc, adresse_image=$element_img_addr, titre_image=$element_img_titre, desc_image=$element_img_desc"
# Ajout des éléments dans les tableaux appropriés # Ajout des éléments dans les tableaux appropriés
elements_titre[$curseur_element]=${element_titre:-""} eval "elements_titre_${curseur_element}=\"${element_titre:-""}\""
elements_url[$curseur_element]=${element_url:-""} eval "elements_url_${curseur_element}=\"${element_url:-""}\""
elements_desc[$curseur_element]=${element_desc:-""} eval "elements_desc_${curseur_element}=\"${element_desc:-""}\""
elements_image_addr[$curseur_element]=${element_img_addr:-""} eval "elements_image_addr_${curseur_element}=\"${element_img_addr:-""}\""
elements_image_titre[$curseur_element]=${element_img_titre:-""} eval "elements_image_titre_${curseur_element}=\"${element_img_titre:-""}\""
elements_image_desc[$curseur_element]=${element_img_desc:-""} eval "elements_image_desc_${curseur_element}=\"${element_img_desc:-""}\""
# Incrémentation du curseur du tableau contenant les éléments # Incrémentation du curseur du tableau contenant les éléments
curseur_element=$(( $curseur_element + 1 )) curseur_element=$(( $curseur_element + 1 ))
fi fi
done done
else else
# le fichier ne contient pas de ligne. message d'erreur # le fichier ne contient pas de ligne. message d'erreur
echo -e "Fichier '$fichier' non pris en charge : Le fichier semble vide." echo "Fichier '$fichier' non pris en charge : Le fichier semble vide."
fi fi
# On débute la création du fichier contenant la catégorie si CATEG=1 # On débute la création du fichier contenant la catégorie si CATEG=1
if [[ $CATEG == 1 ]] if [ "$CATEG" -eq 1 ]
then then
echo -e "Création d'un bloc Catégorie…" echo "Création d'un bloc Catégorie…"
# Tests sur la valeur de la catégorie et de l'état du curseur # Tests sur la valeur de la catégorie et de l'état du curseur
debug "Catégorie : $categ_titre : $categ_desc" debug "Catégorie : $categ_titre : $categ_desc"
debug "État curseur : $curseur_element" debug "État curseur : $curseur_element"
@ -182,22 +183,28 @@ do
i=0 i=0
# Parcours des tableaux afin de récupérer toutes les informations # Parcours des tableaux afin de récupérer toutes les informations
#+ d'un élément #+ d'un élément
while [ $i -lt $curseur_element ] while [ "$i" -lt "$curseur_element" ]
do do
# Assignation des valeurs à des variables afin de l'afficher # Assignation des valeurs à des variables afin de l'afficher
e_titre=${elements_titre[$i]:-""} # titre element e_titre_tmp=$(eval echo \$elements_titre_${i})
e_desc=${elements_desc[$i]:-""} # description element e_titre=${e_titre_tmp:-""} # titre element
e_url=${elements_url[$i]:-""} # url element e_desc_tmp=$(eval echo \$elements_desc_${i})
e_img_addr=${elements_image_addr[$i]:-""} # adresse image e_desc=${e_desc_tmp:-""} # description element
e_img_titre=${elements_image_titre[$i]:-""} # titre image e_url_tmp=$(eval echo \$elements_url_${i})
e_img_desc=${elements_image_desc[$i]:-""} # description image e_url=${e_url_tmp:-""} # url element
e_img_addr_tmp=$(eval echo \$elements_image_addr_${i})
e_img_addr=${e_img_addr_tmp:-""} # adresse image
e_img_titre_tmp=$(eval echo \$elements_image_titre_${i})
e_img_titre=${e_img_titre_tmp:-""} # titre image
e_img_desc_tmp=$(eval echo \$elements_image_desc_${i})
e_img_desc=${e_img_desc_tmp:-""} # description image
# Affichage du résultat # Affichage du résultat
debug "$i : ${e_titre} || ${e_desc} || ${e_url} || ${e_img_addr} || ${e_img_titre} || ${e_img_desc}" debug "$i : ${e_titre} || ${e_desc} || ${e_url} || ${e_img_addr} || ${e_img_titre} || ${e_img_desc}"
# Ajout des informations dans le fichier de destination # Ajout des informations dans le fichier de destination
echo -e "\t…ajout de l'élément '${e_titre}'" printf "\t…ajout de l'élément '${e_titre}'\n"
cat $elem |sed -e "s|@@TITRE_ELEMENT@@|$e_titre|g" -e "s|@@DESC_ELEMENT@@|${e_desc}|g" -e "s|@@URL_ELEMENT@@|${e_url}|g" -e "s|@@URL_IMAGE@@|${e_img_addr}|g" -e "s|@@TITRE_IMAGE@@|${e_img_titre}|g" -e "s|@@DESC_IMAGE@@|${e_img_desc}|g" -e "s|^\(.*\)@@.*@@\(.*\)$|\1\2|g" >> ${destination} cat $elem |sed -e "s|@@TITRE_ELEMENT@@|$e_titre|g" -e "s|@@DESC_ELEMENT@@|${e_desc}|g" -e "s|@@URL_ELEMENT@@|${e_url}|g" -e "s|@@URL_IMAGE@@|${e_img_addr}|g" -e "s|@@TITRE_IMAGE@@|${e_img_titre}|g" -e "s|@@DESC_IMAGE@@|${e_img_desc}|g" -e "s|^\(.*\)@@.*@@\(.*\)$|\1\2|g" >> ${destination}
# Incrémentation de l'index # Incrémentation de l'index
let i++ i=`expr $i + 1` #let i++
done done
# Ajout de la fin du fichier pour les catégories (FIN) # Ajout de la fin du fichier pour les catégories (FIN)
cat $categ_fin >> ${destination} cat $categ_fin >> ${destination}