1
0
mirror of https://tildegit.org/sbgodin/HtmGem.git synced 2023-08-25 13:53:12 +02:00

Manages the styles. WIP.

This commit is contained in:
Christophe HENRY 2021-03-09 11:26:31 +01:00
parent 11ced8627b
commit 1a01e8bd81
5 changed files with 191 additions and 21 deletions

21
css/simple.css Normal file
View File

@ -0,0 +1,21 @@
body {
max-width: 1024px;
margin: auto;
margin-top: 0.5em;
}
p, h1, h2, h3 {
margin: 0 0 0.3rem;
padding: 0;
}
blockquote {
border-left: 3px solid #444;
margin: 1rem -1rem 1rem calc(-1rem - 3px);
padding: 1rem;
}
pre {
padding: 1rem;
overflow-x: auto;
}

View File

@ -30,8 +30,28 @@ Il est supposé que HtmGem est installé à la racine du site dans un répertoir
🢂 Enfin, pour vérifier que le fichier //index.gmi// est automatiquement appelé quand le fichier //**.gmi**// nest pas indiqué :
=> / Lien vers la racine du site
———————————————————— ————————————————————
# Configuration avancée avec les styles
Par défaut, le style est incorporé dans chaque page récupérée par le navigateur web. Le même style est utilisé pour toutes les pages, //htmgem/css/htmgem.css//, sauf lorsquun fichier ayant le même nom que la page mais avec lextension **.css** existe. Dans ce cas, il est utilisé.
Lorsque loption css est activé dans la configuration (voir //rewrite// plus haut) dautres comportements sont possibles :
* &style=source : le code source de la page est envoyée au navigateur, voir ci-après…
* &style=htmgem : utilise le style par défaut, mais en tant que fichier externe
* &style=none : la page HTML est envoyée sans style
* &style=<autre nom> : le fichier htmgem/css/<autre nom>.css est utilisé en tant que style externe
* &style=/<path> : le fichier indiqué (chemin absolu) est utilisé en tant que style externe
## Réécriture dURL pour afficher le code source
Pour obtenir le source avec un lien du type
=> index.gmi.source
Il faut ajouter la ligne suivante pour la réécriture dURL :
> rewrite ^(.+\.gmi)\.source$ /htmgem/?url=$1&style=source;
# Quand tout marche…
Parmi les fichiers distribués, seuls sont utiles :
Parmi les fichiers et répertoires distribués, seuls sont utiles :
* **htmgem/index.php** : Il se charge de traduire le gemtext en HTML
* **htmgem/htmgem.css** : Sil manque, laffichage sera dépourvu de style — littéralement.
* **htmgem/css/htmgem.css : Sil manque, laffichage sera dépourvu de style — littéralement.
Les autres peuvent être supprimés (y compris ce présent fichier) bien quils ne présentent aucun danger. Ils restent nécessaires au développement du projet et son disponible sur le site de HtmGem.

View File

@ -12,9 +12,14 @@ define("DASHES"
."" # U+2E3B Three-Em Dash (Three times larger than a single char)
);
$url = @$_REQUEST["url"];
$style = @$_REQUEST['style'];
/* The url argument is always absolute compared to the document root
* The leading slash is removed. so url=/foo/bar and url=foo/bar ar the same.
*/
$url = @$_REQUEST["url"];
######################################## Installation page
if (empty($url)) {
if (!file_exists("index.gmi")) {
@ -28,7 +33,7 @@ if (empty($url)) {
<title>Installation de HtmGem</title>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8">
<style>
<?php include("htmgem.css"); ?>
<?php include("css/htmgem.css"); ?>
</style>
</head>
<body>
@ -39,33 +44,34 @@ if (empty($url)) {
}
######################################## /Installation page
# Removes the trailling slash, to be sure there's not any.
$GMI_DIR = rtrim($_SERVER['DOCUMENT_ROOT'], "/");
$filePath = $GMI_DIR."/".$url;
# Removes the headling and trailling slashes, to be sure there's not any.
$filePath = rtrim($_SERVER['DOCUMENT_ROOT'], "/")."/".ltrim($url, "/");
$fileContents = @file_get_contents($filePath);
######################################## 404 page
if (empty($fileContents)) {
error_log("HtmGem: 404 $url $filePath");
http_response_code(404); ?>
<!DOCTYPE html>
<html lang="fr">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8">
<style>
<?php include("htmgem.css"); ?>
<?php include("css/htmgem.css"); ?>
</style>
</head>
<body>
<?php
$text404 = <<<EOF
# Page non trouvée
# Page non trouvée
**$url**
=> $url rééssayer ?
=> / index
=> $url 🔄
=> /
EOF;
echo translateGemToHtml($text404);
echo "</body>\n</html>";
@ -278,25 +284,59 @@ function translateGemToHtml($fileContents) {
mb_ereg("#\s*([^\n]+)\n", $fileContents, $matches);
$page_title = @$matches[1];
# <!-- link type="text/css" rel="StyleSheet" href="/htmgem.css" -->
echo <<<EOL
###################################### CSS Management
/**
* if &style=source displays the source directly and stops.
* if there's a filename.css besides filename.gmi, use the css and stops.
* if &style=<NOTHING> then embbed the default style, and stops.
* if &style=<word not beginngin by slash> then use htmgem/word.css
* if &style=/ then use the as as stylesheet.
**/
if ("source" == $style) {
echo $fileContents;
} else {
$parts = pathinfo($filePath);
$localCss = $parts["filename"].".css";
$localCssFilePath = $parts["dirname"]."/".$localCss;
if (file_exists($localCssFilePath)) {
# Warning, using htmhem.php?url=… will make $localCss not found
# as the path is relative to htmgem.php and not / !
$cssContent = "<link type='text/css' rel='StyleSheet' href='$localCss'>";
} else {
if (empty($style)) {
$cssContent =
"<style>\n"
.@file_get_contents("css/htmgem.css")
."</style>\n";
} else {
if ("none" == $style) {
$cssContent = "";
} else {
if ("/" == $style[0])
$href = $style;
else
$href = "/htmgem/css/$style.css";
$cssContent = "<link type='text/css' rel='StyleSheet' href='$href'>";
}
}
}
echo <<<EOL
<!DOCTYPE html>
<html lang="fr">
<head>
<title>$page_title</title>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8">
<style>
EOL;
include("htmgem.css");
echo <<<EOL
</style>
$cssContent
</head>
<body>
EOL;
echo "\n".translateGemToHtml($fileContents);
echo "</body>\n</html>\n";
echo "\n".translateGemToHtml($fileContents);
echo "</body>\n</html>\n";
}
ob_end_flush();
?>

89
tests/tutogemtext.gmi Normal file
View File

@ -0,0 +1,89 @@
Gemini se découpe en son protocole (comme HTTP) et son language, GemText. Ici, je vais approfondir ce quest le langage GemText. Son principe est que cest le programme de lutilisateur (le navigateur web, pour HTTP) qui décide de laffichage. La police de caractère, la taille, le fond décran, tout. À lexception du texte et de quelques autres détails qui suivent.
Si vous utilisez un programme qui ninterprète pas tous les styles de lignes, certaines vous sembleront dupliquées…
La ligne que vous venez de lire existe sur une ligne physique, que le programme que vous utilisez a dû découper en plusieurs lignes logiques afin que cela tienne sur votre écran. Entre cette présente ligne de texte et celle davant, il y a une ligne vide pour marquer le changement de paragraphe.
Ici, jai simplement passé à la ligne. Lespacement devrait être moindre.
Il y a tout de même quelques types spéciaux de ligne.
On commence par le titre de niveau 1. Il est dabord écrit ci-après tel que je le vois, puis sur la ligne daprès il est rendu normalement par votre programme :
# Comment fonctionne GemText ?
# Comment fonctionne GemText ?
Je viens décrire « # Comment fonctionne GemText » deux fois. Une fois sans quil soit interprété, où vous le voyez tel que je le vois. Et une deuxième fois où votre programme peut lafficher différemment.
# Titre de niveau 1
# Titre de niveau 1
## Titre de niveau 2
## Titre de niveau 2
### Titre de niveau 3
### Titre de niveau 3
# Les citations
Quand on veut citer un texte, on écrit avec le caractère > en début de ligne. Dabord affichée comme je lai écrit puis comme le programme laffiche normalement :
> Citation de texte. La ligne peut être aussi longue que voulue, cest votre programme qui doit découper la ligne pour lafficher. Une seule ligne physique peut être longue, mais il ny a pas besoin de placer de retour à la ligne.
> Citation de texte. La ligne peut être aussi longue que voulue, cest votre programme qui doit découper la ligne pour lafficher. Une seule ligne physique peut être longue, mais il ny a pas besoin de placer de retour à la ligne.
# Les blocs préformatés
Les blocs préformatés sont des lignes encadrées par un ``` sur une ligne avant le bloc et un ``` après le bloc. Les lignes contenant ``` ne sont pas affichées :
```
Ceci est une ligne préformatée. Quand la ligne est longue, elle nest pas découpée. Le programme doit présenter un ascenseur horizontal pour permettre de tout voir.
```
```
Ceci est une ligne préformatée. Quand la ligne est longue, elle nest pas découpée. Le programme doit présenter un ascenseur horizontal pour permettre de tout voir.
```
# Les listes non-ordonnées
* Les listes non-ordonnées sont des lignes commençant par * les unes après les autres.
* Elles servent à énumérer.
* Par contre, GemText ne reconnaît pas les listes numérotées.
* Les listes non-ordonnées sont des lignes commençant par * les unes après les autres.
* Elles servent à énumérer.
* Par contre, GemText ne reconnaît pas les listes numérotées.
# Les liens
Il ne peut exister quun lien par ligne. Et la ligne est dédiée à ça ! Voici par exemple un lien vers le site centralisant pour le moment les informations sur Gemini :
=> gemini://gemini.circumlunar.space/docs/specification.gmi Spécifications de Gemini
=> gemini://gemini.circumlunar.space/docs/specification.gmi Spécifications de Gemini
Voici un autre lien, directement visible parce quil na pas de description :
=> https://gemini.circumlunar.space/docs/specification.gmi
=> https://gemini.circumlunar.space/docs/specification.gmi
# Ce que jai mis en plus…
HtmGem suit les préconisations de Gemini, sauf pour quelques ajouts… Attention, le texte formaté ne saffiche — à cette heure — que via HtmGem. Vous nen voyez que les caractères déclenchant le formatage. Mais le texte reste néanmoins lisible.
^ Quand on veut signifier que le texte est en **gras** on y met des astérisques autour. De même pour les mots __soulignés__, ceux écrits en //italique// ou même quand on les ~~barre~~.
Mais jestime que le format GemText est alors pas assez **expressif** et quil se prive de capacités utiles qui ne sont vraiment pas dures à //concevoir//. Idéalement, on tendrait vers lédition de livres électroniques.
Alors voici ce que jy ajoute :
* Par défaut, le texte mis en forme sapplique sur les lignes de texte, listes et citations.
* Pour désactiver la mise en forme du texte, on peut soit commencer la ligne par ^, soit faire un bloc non formaté avec ^^^ :
^ Avec un ^ au début de cette ligne le texte apparaît ~~sans~~ la mise en forme.
# HtmGem
HtmGem est un programme écrit en Php permettant daccéder à un serveur web rendant les pages Gemini. Il traduit chaque page Gemini en Html.
=> https://git.sr.ht/~sbgodin/htmgem Code source de HtmGem
=> https://gmi.sbgodin.fr Ma page personnelle qui utilise HtmGem
=> gemini://gmi.sbgodin.fr Ma page personnelle en passant nativement par un programme interprétant Gemini
### License de cette page
Cette page est sous licence libre **CC BY-SA 2.0 FR**.
=> https://creativecommons.org/licenses/by-sa/2.0/fr/ Texte de la licence CC BY-SA 2.0 FR
=> gemini://gmi.sbgodin.fr/ gemini://gmi.sbgodin.fr/ ⸻ Christophe HENRY
### Navigation
=> ..