2011-02-23 21:42:16 +00:00
|
|
|
########################
|
|
|
|
## Programme PorteAil ##
|
|
|
|
########################
|
|
|
|
|
|
|
|
### À PROPOS ###
|
|
|
|
|
|
|
|
PorteAil est un portail web dont le but principal est, comme son nom l'indique,
|
|
|
|
de partager un ensemble de liens amenant vers divers lieux.
|
|
|
|
|
|
|
|
Cf. http://fr.wikipedia.org/wiki/Portail_%28web%29 pour de plus amples
|
|
|
|
informations.
|
|
|
|
|
|
|
|
PorteAil est un jeu de mot entre Porte, portail et Ail (l'aliment ou le bruit
|
|
|
|
que nous faisons après avoir eu mal ?).
|
|
|
|
|
|
|
|
### PRÉ - REQUIS ###
|
|
|
|
|
|
|
|
Ce programme fonctionne à l'aide de **GNU Make**.
|
|
|
|
|
|
|
|
Il requièrt également quelques commandes du SHELL sh comme :
|
|
|
|
- echo
|
|
|
|
- test
|
|
|
|
- rm
|
|
|
|
- cat
|
|
|
|
|
|
|
|
### DESCRIPTION ###
|
|
|
|
|
|
|
|
Le script makefile permet de générer un dossier contenant les fichiers
|
|
|
|
suivants :
|
|
|
|
- index.html : page de garde du portail web 'PorteAil'
|
|
|
|
- defaut.css : feuille de style de PorteAil
|
|
|
|
- img : dossier contenant l'ensemble des fichiers images (icônes) pour
|
|
|
|
l'affichage des éléments dans la page de garde
|
|
|
|
|
2011-03-09 07:32:19 +00:00
|
|
|
### DÉPENDANCES ###
|
|
|
|
|
|
|
|
Le programme requièrt les programmes suivants :
|
|
|
|
- GNU make
|
|
|
|
- cp
|
|
|
|
- sed
|
|
|
|
- bash
|
|
|
|
- echo
|
|
|
|
- test
|
|
|
|
- cat
|
|
|
|
- wc
|
|
|
|
- grep
|
|
|
|
|
2011-03-09 21:32:15 +00:00
|
|
|
Normalement ces éléments sont inclus de base dans une distribution GNU/Linux
|
|
|
|
et/ou BSD.
|
2011-02-23 21:42:16 +00:00
|
|
|
|
2011-03-09 21:32:15 +00:00
|
|
|
### INSTALLATION ###
|
2011-03-09 07:32:19 +00:00
|
|
|
|
2011-03-09 21:32:15 +00:00
|
|
|
Le programme ne requièrt aucune installation particulière. Placez le où vous
|
|
|
|
voudrez.
|
2011-02-23 21:42:16 +00:00
|
|
|
|
|
|
|
### UTILISATION ###
|
|
|
|
|
2011-03-09 21:32:15 +00:00
|
|
|
Dans sa version 0.1 le programme s'utilise via plusieurs entrées minimales :
|
|
|
|
- le fichier GNUmakefile
|
|
|
|
- le dossier categ
|
|
|
|
- le fichier composants/introduction.html
|
|
|
|
- le fichier composants/menu.html
|
|
|
|
- le dossier img
|
|
|
|
|
|
|
|
Pour chaque élément, veuillez vous référer au chapitre adéquat.
|
|
|
|
|
|
|
|
Si vous désirez personnaliser encore plus la page PorteAil, vous pouvez
|
|
|
|
lire la section « Pour aller plus loin » qui permet de comprendre un
|
|
|
|
peu mieux le fonctionnement du programme.
|
|
|
|
|
|
|
|
#--[[ Mode de fonctionnement basique ]]--#
|
|
|
|
|
|
|
|
Pour utiliser le programme, il suffit d'utiliser une console (shell),
|
|
|
|
d'aller dans le dossier contenant PorteAil, et de faire :
|
|
|
|
|
|
|
|
make
|
|
|
|
|
|
|
|
En théorie un nouveau dossier 'porteail' apparaît dans lequel il y a :
|
|
|
|
- un fichier 'index.html'
|
|
|
|
- une feuille de style nommée 'defaut.css'
|
|
|
|
- un dossier 'img' contenant tout un tas d'image
|
|
|
|
|
|
|
|
Si vous voulez supprimer les fichiers crées à l'aide de la commande
|
|
|
|
'make' ou pour toute autre raison, faites :
|
|
|
|
|
|
|
|
make clean
|
|
|
|
|
|
|
|
et cela aura pour effet de supprimer le dossier 'porteail' et le fichier
|
|
|
|
'categories.html' crée par différents scripts au moment de la génération
|
|
|
|
de la page.
|
|
|
|
|
|
|
|
#--[[ GNUmakefile ]]--#
|
|
|
|
|
|
|
|
Ce fichier vous permettra de changer le titre de la page PorteAil et
|
|
|
|
le titre affiché dans un navigateur. Ceci se fait via les deux
|
|
|
|
lignes suivantes :
|
|
|
|
|
|
|
|
- TITRE=
|
|
|
|
- ACCUEIL=
|
|
|
|
|
|
|
|
Par exemple pour afficher "Mon super site" sur la page PorteAil et
|
|
|
|
avoir "Accueil - Mon super site" dans l'onglet du navigateur, il
|
|
|
|
suffit de changer les lignes suivantes du fichier GNUmakefile :
|
|
|
|
|
|
|
|
TITRE = Mon super site
|
|
|
|
ACCUEIL = Accueil - $(TITRE)
|
|
|
|
|
|
|
|
Il faut savoir que '$(TITRE)' va se changer en 'Mon super site'.
|
|
|
|
C'est la notion même de variables en programmation. Mais passons.
|
|
|
|
|
|
|
|
Ces deux variables sont les seules à modifier pour une utilisation
|
|
|
|
simple du programme.
|
|
|
|
|
|
|
|
#--[[ Le dossier 'categ' ]]--#
|
|
|
|
|
|
|
|
Le dossier 'categ' est le dossier qui va contenir nos catégories
|
|
|
|
d'éléments.
|
|
|
|
Il faut savoir que :
|
|
|
|
- un fichier texte portant l'extension '.txt' est considéré comme
|
|
|
|
UNE catégorie
|
|
|
|
- le programme n'accepte que les fichiers comportant une et une
|
|
|
|
seule description de catégorie
|
|
|
|
- le programme va lire les éléments renseignés dans le fichier
|
|
|
|
|
|
|
|
Le format de fichier accepte 3 cas possible de lignes :
|
|
|
|
1. les commentaires
|
|
|
|
2. une description d'une catégorie
|
|
|
|
3. une description d'un élément
|
|
|
|
|
|
|
|
Voici un commentaire :
|
|
|
|
|
|
|
|
# un commentaire dans le fichier
|
|
|
|
|
|
|
|
Voici une description de catégorie :
|
|
|
|
|
|
|
|
[[Titre de ma catégorie]]Description de ma catégorie
|
|
|
|
|
|
|
|
Voici une description d'un élément (un par ligne) :
|
|
|
|
|
|
|
|
Titre##URL##DESC##ADDR_IMG##TITRE_IMG##DESC_IMG
|
|
|
|
|
|
|
|
où :
|
|
|
|
|
|
|
|
- Titre : est le nom affiché sur le portail de l'élément.
|
|
|
|
- URL : est l'adresse COMPLÈTE du site sur lequel on pointe
|
|
|
|
- DESC : est la description complète de notre élément pour le passage de la
|
|
|
|
souris sur le lien
|
|
|
|
- ADDR_IMG : est l'adresse relative vers l'image (Cf. ci-après pour plus de
|
|
|
|
renseignements)
|
|
|
|
- TITRE_IMG : est le titre de notre image (si jamais l'image ne s'affiche pas)
|
|
|
|
- DESC_IMG : est la description de l'image au passage de la souris
|
|
|
|
|
|
|
|
Des exemples sont donnés dans le dossier categ. À vous de les modifier comme
|
|
|
|
bon vous semble.
|
|
|
|
|
|
|
|
#--[[ Le dossier 'img' et Adresse de l'image ]]--#
|
|
|
|
|
|
|
|
Dans la version 0.1, il faut indiquer clairement l'adresse de l'image à
|
|
|
|
utiliser pour la page de PorteAil.
|
|
|
|
Sachant que le dossier 'img' contient l'ensemble des images disponibles,
|
|
|
|
il faut tout d'abord trouver l'adresse d'une image qu'on voudrait, par
|
|
|
|
exemple 'apps/clock.png'.
|
|
|
|
|
|
|
|
Il faut donc concaténer deux chaînes de caractères :
|
|
|
|
- './image/' qui est le dossier de destination
|
|
|
|
- 'apps/clock.png' qui est l'adresse de l'image actuellement
|
|
|
|
|
|
|
|
Ainsi cela ressemble à :
|
|
|
|
|
|
|
|
./image/apps/clock.png
|
|
|
|
|
|
|
|
#--[[ Le fichier introduction.html ]]--#
|
|
|
|
|
|
|
|
Le fichier 'composants/introduction.html' contient du texte en HTML à
|
|
|
|
insérer en début de la page PorteAil, il faut donc connaître un peu le
|
|
|
|
langage HTML pour permettre un affichage correct de ce que vous voulez.
|
|
|
|
|
|
|
|
Par défaut cet élément n'est pas activé. Pour l'activer il suffit de
|
|
|
|
changer la ligne suivante dans le fichier 'GNUmakefile' :
|
|
|
|
|
|
|
|
#INTRO = $(DOSSIER_HTML)/introduction.html
|
|
|
|
|
|
|
|
par
|
|
|
|
|
|
|
|
INTRO = $(DOSSIER_HTML)/introduction.html
|
|
|
|
|
|
|
|
Vous l'aurez compris, il suffit d'enlever le premier dièse '#' du début de
|
|
|
|
ligne.
|
|
|
|
|
|
|
|
#--[[ Le fichier menu.html ]]--#
|
|
|
|
|
|
|
|
À l'instar du fichier 'introduction.html', le fichier 'menu.html' permet
|
|
|
|
d'insérer un menu dans la page du PorteAil. Ceci est très utile si vous
|
|
|
|
voulez agrémenter le portail de tout un tas d'autres pages.
|
|
|
|
|
|
|
|
Par défaut cet élément n'est pas activé. Pour l'activer il suffit de
|
|
|
|
changer la ligne suivante dans el fichier 'GNUmakefile' :
|
|
|
|
|
|
|
|
#MENU = $(DOSSIER_HTML)/menu.html
|
|
|
|
|
|
|
|
par
|
|
|
|
|
|
|
|
MENU = $(DOSSIER_HTML)/menu.html
|
|
|
|
|
|
|
|
Comme pour l'introduction, il suffit de supprimer le dièse '#' en début de
|
|
|
|
ligne.
|
|
|
|
|
|
|
|
### POUR ALLER PLUS LOIN ###
|
|
|
|
|
|
|
|
Tous les éléments expliqués ci-avant ne seront que partiellement ou pas du
|
2011-03-10 12:17:54 +00:00
|
|
|
tout expliqué pour des raisons évidentes de redondance d'information.
|
2011-03-09 21:32:15 +00:00
|
|
|
|
|
|
|
Nous allons donc aborder plusieurs points qui concernent la personnalisation
|
|
|
|
de PorteAil afin d'adapter le programme pour qu'il en résulte une page d'une
|
|
|
|
structure différente de celle de base.
|
|
|
|
|
|
|
|
Cela est utile dans le cas où :
|
|
|
|
- vous connaissez le langage HTML pour faire des pages internet
|
|
|
|
- vous connaissez le langage CSS pour manier visuellement la page sans modifier
|
|
|
|
le contenu
|
|
|
|
- vous n'avez pas peur de modifier quelques lignes dans des fichiers afin de
|
|
|
|
voir le résultat
|
|
|
|
|
2011-03-10 12:17:54 +00:00
|
|
|
#--[[ Utilisation de la commande make ]]--#
|
|
|
|
|
|
|
|
Pour plus d'informations sur l'utilisation de la commande 'make', je vous
|
|
|
|
renvoie à la page de manuel disponible en tapant :
|
|
|
|
|
|
|
|
man make
|
|
|
|
|
|
|
|
Cependant sachez que dans le fichier 'GNUmakefile' il existe plusieurs sections
|
|
|
|
susceptibles d'être utilisées. Les principales sont :
|
|
|
|
- all : génère la page de PorteAil après avoir fait divers tests d'existence
|
|
|
|
des éléments.
|
|
|
|
- clean : permet de nettoyer le dossier nommé 'porteail'
|
|
|
|
- test : fait quelques tests sur l'existence des ficheirs nécessaires pour
|
|
|
|
la compilation de la page.
|
|
|
|
|
|
|
|
#--[[ GNUmakefile ]]--#
|
|
|
|
|
|
|
|
Le fichier GNUmakefile contient un ensemble de variables qui sont utiles pour
|
|
|
|
personnaliser la page de résultat. Voici une liste et la description attachée
|
|
|
|
pour chacun des éléments modifiable/utilisable dans le fichier 'GNUmakefile' :
|
|
|
|
|
|
|
|
DESTINATION : nom du dossier dans lequel ira le résultat de la génération
|
|
|
|
|
|
|
|
INDEX : adresse, à partir du répertoire dans lequel est contenu le fichier
|
|
|
|
'GNUmakefile', dans lequel se trouvera le fichier résultant. Cela donne une
|
|
|
|
indication sur le nom que vous voulez donner au fichier
|
|
|
|
|
|
|
|
CSS_SANS_MENU : nom de la feuille de style à utiliser quand la page est générée
|
|
|
|
sans menu. À noter que le fichier doit se trouver dans le dossier 'composants'
|
|
|
|
|
|
|
|
CSS_AVEC_MENU : nom de la feuille de style à utiliser quand la page est générée
|
|
|
|
avec un menu. À noter que le fichier doit se trouver dans le dossier
|
|
|
|
'composants'.
|
|
|
|
|
|
|
|
CSS_NOM : nom de la feuille de style dans le résultat final
|
|
|
|
|
|
|
|
TITRE : Cf. Chapitre 'GNUmakefile' ci-avant.
|
|
|
|
|
|
|
|
ACCUEIL : Cf. Chapitre 'GNUmakefile' ci-avant.
|
|
|
|
|
|
|
|
DOSSIER_HTML : nom du dossier contenant l'ensemble des composants. Cf Chapitre
|
|
|
|
sur les composants 'Les composants'.
|
|
|
|
|
|
|
|
MENU : Cf. Chapitre 'Le fichier menu.html'
|
|
|
|
|
|
|
|
INTRO : Cf. Chapitre 'Le fichier introduction.html'
|
|
|
|
|
|
|
|
Quelques autres éléments sont modifiables : les composants. Les valeurs
|
|
|
|
attachées à ces composants sont les suivantes :
|
|
|
|
|
|
|
|
- entete : fichier entete.html
|
|
|
|
- enqueue : fichier enqueue.html
|
|
|
|
- contenu_fin : fichier contenu_fin.html
|
|
|
|
- script_contenu : script bash permettant de générer les catégories
|
|
|
|
- contenu : fichier temporaire possédant le contenu à insérer dans la page
|
|
|
|
|
|
|
|
Pour plus de renseignements, veuillez vous référer au chapitre 'Les
|
|
|
|
composants'.
|
|
|
|
|
|
|
|
##--[[ Les composants ]]--#
|
|
|
|
|
|
|
|
Les composants sont les éléments qui permettent de composer la page.
|
|
|
|
À cet effet une page a été scindés en les éléments suivants :
|
|
|
|
- entete.html : contient le début de notre page HTML
|
|
|
|
- categ_deb.html : contient le début d'une catégorie
|
|
|
|
- element.html : contient l'ensemble du HTML pour UN élément donné
|
|
|
|
- categ_fin.html : contient la fin d'une catégorie
|
|
|
|
- contenu_fin.html : contient la fin du corps de la page
|
|
|
|
- enqueue.html : contient le pied de page
|
|
|
|
- introduction.html : contient du HTML pouvant être ajouté après le titre
|
|
|
|
principal de la page
|
|
|
|
- menu.html : un menu à ajouter à notre page
|
|
|
|
|
|
|
|
Pour personnaliser il suffit d'éditer chacun des fichiers afin d'en
|
|
|
|
modifier le code source.
|
|
|
|
|
|
|
|
#--[[ La création des catégorie à l'aide de creation_categ.sh ]]--#
|
|
|
|
|
2011-03-09 21:32:15 +00:00
|
|
|
#FIXME
|
|
|
|
- creation_categ.sh - personnalisation
|
|
|
|
- le dossier style
|
|
|
|
- le dossier img
|
|
|
|
|
2011-03-09 07:32:19 +00:00
|
|
|
|
2011-02-23 21:42:16 +00:00
|
|
|
### SOURCES ###
|
|
|
|
|
2011-03-09 07:32:19 +00:00
|
|
|
Les sources du programme peuvent être récupérées sur
|
|
|
|
http://git.dossmann.net/ ou via la commande suivante (à l'aide de l'outil
|
|
|
|
git) :
|
2011-02-23 21:42:16 +00:00
|
|
|
|
|
|
|
git clone http://git.dossmann.net/scripts/porteail.git
|
|
|
|
|