TODO
Le développement et le deploiement de FreshRSS peuvent se faire via Docker.
TODO
Si vous désirez contribuer au code, il est important de respecter le style de codage suivant. Le code actuel ne le respecte pas entièrement mais il est de notre devoir à tous de le changer dès que l'occasion se présente.
Aucune nouvelle contribution ne respectant pas ces règles ne sera acceptée tant que les corrections nécessaires ne sont pas appliquées.
L'indentation du code doit être faite impérativement avec des tabulations.
Une fois l'indentation faite, il peut être nécessaire de faire un alignement pour simplifier la lecture. Dans ce cas, il faut utiliser les espaces.
$resultat = une_fonction_avec_un_nom_long($param1, $param2,
$param3, $param4);
Le caractère de fin de ligne doit être un saut de ligne (LF) qui est le caractère de fin de ligne des systèmes *NIX. Ce caractère ne doit pas être précédé par des caractères blanc.
Il est possible de vérifier la présence de caractères blancs en fin de ligne grâce à Git avec la commande suivante :
# commande à lancer avant l'ajout des fichiers dans l'index
git diff --check
# commande à lancer après l'ajout des fichiers dans l'index mais avant le commit
git diff --check --cached
Chaque fichier doit se terminer par une ligne vide.
Il n'y a pas d'espace avant ces caractères, il y en a un après.
Chaque opérateur est entouré d'espaces.
if ($a == 10) {
// faire quelque chose
}
echo $a ? 1 : 0;
Il n'y a pas d'espaces entre des parenthèses. Il n'y a pas d'espaces avant une parenthèse ouvrante sauf si elle est précédée d'un mot-clé. Il n'y a pas d'espaces après une parenthèse fermante sauf si elle est suivie d'une accolade ouvrante.
if ($a == 10) {
// faire quelque chose
}
if ((int)$a == 10) {
// faire quelque chose
}
Ce cas se présente le plus souvent en Javascript. Quand on a des fonctions chainées, des fonctions anonymes ainsi que des fonctions de rappels, il est très facile de se perdre. Dans ce cas là, on ajoute une indentation supplémentaire pour toute l'instruction et on revient au même niveau pour une instruction de même niveau.
// Première instruction
shortcut.add(shortcuts.mark_read, function () {
//...
}, {
'disable_in_input': true
});
// Deuxième instruction
shortcut.add("shift+" + shortcuts.mark_read, function () {
//...
}, {
'disable_in_input': true
});
Les lignes ne doivent pas dépasser 80 caractères. Il est cependant autorisé exceptionnellement de dépasser cette limite s'il n'est pas possible de la respecter mais en aucun cas, les lignes ne doivent dépasser les 100 caractères.
Dans le cas des fonctions, les paramètres peuvent être déclarés sur plusieurs lignes.
function ma_fonction($param_1, $param_2,
$param_3, $param_4) {
// faire quelque chose
}
L'ensemble des éléments du code (fonctions, classes, méthodes et variables) doivent être nommés de manière à décrire leur usage de façon concise.
Les fonctions et les variables doivent suivre la convention "snake case".
// une fontion
function nom_de_la_fontion() {
// faire quelque chose
}
// une variable
$nom_de_la_variable;
Les méthodes doivent suivre la convention "lower camel case".
private function nomDeLaMethode() {
// faire quelque chose
}
Les classes doivent suivre la convention "upper camel case".
abstract class NomDeLaClasse {}
Les fichiers doivent être encodés en UTF-8.
Assurez-vous que votre code fonctionne avec une version de PHP aussi ancienne que celle que FreshRSS supporte officiellement.
Les opérateurs doivent être en fin de ligne dans le cas de conditions sur plusieurs lignes.
if ($a == 10 ||
$a == 20) {
// faire quelque chose
}
Si le fichier ne contient que du PHP, il ne doit pas comporter de balise fermante
Lors de l'écriture de tableaux sur plusieurs lignes, tous les éléments doivent être suivis d'une virgule (même le dernier).
$variable = [
"valeur 1",
"valeur 2",
"valeur 3",
];