summaryrefslogtreecommitdiff
path: root/src/posts/2024-04-10-la-magie-de-l-ast-de-pandoc.md
blob: 50fcf9438ae7f0aa42b78c5a1bbedd03ed6880be (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
---
title: "La magie de l'AST de Pandoc"
date: 2024-04-10
subtitle: "Nouvel essai pour intégrer ekdosis dans stylo"
---

## Nouvel essai pour intégrer ekdosis dans Stylo

Les scripts peuvent être retrouvés sur [ce dépôt
gitlab](https://gitlab.huma-num.fr/ecrinum/stylo/ekdosis4stylo/-/tree/master/test_lua-filter?ref_type=heads)

### Fonctionnement

Dans ce dossier nous trouvons une autre méthode pour intégrer ekdosis à Stylo.

Pandoc interprète les balises LaTeX lorsqu'elle se trouvent dans des documents
en Markdown.

Pour observer cette interprétation, il faut aller regarder ce qu'il se passe
dans l'AST du document, auquel on accède par la commande suivant :

`pandoc -f markdown -t native sample.md --lua-filter=style-tex.lua -s -i`

On y trouve la chose suivante : `RawInline (Format "tex") "\\emph{emphase}"`.

Au milieu d'un paragraphe (`Para`), Pandoc parse correctement le latex et le
reconnait sous sa forme brute dans un élément _inline_.

Lors d'une transformation en PDF, l'emphase déclarée en latex dans le markdown
sera bien interprétée.

Pour ce qui concerne l'intégration d'ekdosis dans du Markdown nous avons besoin
d'un élément supplémentaire.
Par précaution, il vaut mieux indiquer le package utilisé que l'on déclare
normalement dans le préambule d'un document LaTeX.

Pandoc accepte cette information si elle est indexée dans une en-tête YAML du
document Markdown sous la clef `header-includes`.

Cette information est déclarée dans sample.md :

```yaml
---
title: "Test 1"
header-includes: |
    \usepackage{ekdosis}
---
```

Elle est bien traduite dans l'AST dans le bloc des métadonnées par : 

```
Meta
    { unMeta =
        fromList
          [ ( "header-includes"
            , MetaBlocks
                [ RawBlock (Format "tex") "\\usepackage{ekdosis}" ]
            )
          , ( "title" , MetaInlines [ Str "Test" , Space , Str "1" ] )
          ]
    }
```

Avec ceci nous sommes presque prêt à utiliser ekdosis dans Stylo (en préservant
la
syntaxe ekdosis et le traitement par le compilateur LuaLaTeX tels qu'ils ont été
pensés par R. Alessi).

Pour fonctionner il manque un élément, la balise indiquant l'emploie d'ekdosis
dans le document `\begin{ekdosis}` et `\end{ekdosis}.

Les ajouter manuellement dans le Markdown perdrait l'intérêt de l'utilisation du
Markdown (autant tout faire en LaTeX sinon).
L'idée en cours de test est de rendre ces balises discrètes en utilisant un
filtre LUA où une division en Markdown (inline ou en block) associée à la classe
`variant` ajoute les balises autour du paragraphe où ekdosis est employé.

C'est ce que l'on retrouve dans le filtre `style-tex.lua`.

### Commandes

Pour produire le pdf, utiliser la commande suivante : 

```sh
pandoc sample.md -o sample.pdf -s -i --pdf-engine=lualatex --lua-filter=style-tex.lua
```

### Erreurs

Actuellement, le PDF produit comporte des erreurs puisque l'appareil critiques
avec les variantes ne sont pas affichés en bas de page. Il faut certainement
corriger le filtre LUA.

Affaire à suivre