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
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
|
.. -*- mode: rst -*-
.. -*- coding: utf-8 -*-
Guide d'utilisation de rst2odt
==============================
:date: 2013-05-07
:tags: Libre, reStructuredText
:summary: |summary|
:logo: /images/rstodt/writing_75.jpg
.. figure:: {static}/images/rstodt/writing.jpg
:figwidth: 150
:figclass: floatright
:alt: Bureau
Image : `AJ Cann`_ (creativecommons_)
.. _creativecommons: http://creativecommons.org/licenses/by-nc-sa/2.0/deed.fr
|summary|
.. |summary| replace::
J'ai déjà souvent abordé le langage reStructuredText_ dans mes articles, et
je l'utilise fréquement, que ce soit pour écrire sur ce blog ou publier
d'autres contenus. On présente souvent rst2pdf_ pour la publication, mais
il est également possible de générer une sortie vers libreoffice,
permettant de créer rapidement des documents avec une mise en page
maîtrisée.
.. _reStructuredText: http://docutils.sourceforge.net/docs/ref/rst/introduction.html
.. _rst2pdf: http://rst2pdf.ralsina.com.ar/
Premiers pas
------------
On commence par installer les outils nécessaires :
.. code-block:: console
$ sudo aptitude install rst2odt
et on lance la génération de la manière suivante :
.. code-block:: console
$ rst2odt document.rst document.odt
On peut tout de suite consulter le fichier généré pour voir le résultat. Le
rendu est moins aguicheur que celui généré avec rst2pdf, mais il est possible
de changer ça.
Environnement
-------------
Plutôt que de lancer la commande à chaque fois, il est préférable de se créer
un environnement qui va nous servir chaque fois que nous aurons besoin de
publier un nouveau document.
On va se créer un Makefile pour automatiser la génération du document :
.. code-block:: makefile
resources/template.odt: resources/template.rst
rst2odt resources/template.rst resources/template.odt
%.odt: %.rst resources/template.odt
rst2odt --create-links --strip-comments --stylesheet=resources/template.odt --add-syntax-highlight $< $@
cp $@ resources/templates.odt
Ainsi, il suffira de lancer la commande `make document.odt` pour générer la
sortie à partir du fichier `document.rst` (`document` est bien sûr à adapter en
fonction du nom du fichier sur lequel vous travaillez).
J'ai créé une archive_ qu'il vous suffit de décompresser pour pouvoir
commencer à travailler ; elle comprend le fichier `makeFile` présenté ci-dessus,
ainsi qu'un template contenant des éléments de base.
.. _archive: {static}/resources/rstodt/rst.zip
Utiliser les templates
----------------------
L'avantage d'utiliser un format balisé est que vous n'avez pas vous soucier du
formattage. Le document généré est prêt à être mis en page, vous n'avez plus
qu'à travailler sur le modèle.
La commande `make` a mis à jour le fichier modèle à partir de votre document de
travail. Vous pouvez donc maintenant modifier les styles à travers libreoffice,
ils seront automatiquement intégrés dans vos prochaines étapes de génération.
rst2odt applique ses propres styles au document, ceux-ci héritant des styles
par défaut d'OpenOffice, vous pouvez donc utiliser vos template habituels pour
la mise en forme de votre document. La liste est présentée sur la
documentation_ de l'application.
En séparant le contenu de l'application, on peut ainsi facilement réutiliser un
style d'un document à un autre, on se décharge de la mise en page pendant tout
le temps de la rédaction.
.. _documentation: http://docutils.sourceforge.net/docs/user/odt.html
Aller plus loin
---------------
Le langage reStructuredText utilise des directives_ pour mettre en forme le
texte. Toutes les applications ne les gèrent pas correctement, et certains
outils ont décidé de rajouter leurs propres directives ; bref c'est un peu le
bordel.
La plupart des directives sont correctement prises en compte :
* les tableaux
* les images
* les notes de bas de page (À l'exception près qu'il est impossible de référencer une note de bas de page dans une autre note.)
* la table des matières
* les rôles
Cela devrait répondre à 90 % des usages courants. J'ai déjà présenté un
correctif pour `ajouter la coloration syntaxique`_ dans notre document, et
ainsi utiliser les mêmes directives que rst2pdf_ pour insérer du
code, voici la liste de quelques directives propres à rst2odt :
:meta_: Permet de renseigner les méta-données dans le document.
Et d'autres qui sont plus ou moins bien suportées :
:container_: Permet d'appliquer un style particulier sur un bloc de texte.
:raw_: Pour insérer du code xml au format openDocument.
Au final
--------
C'est bien pratique de pouvoir écrire son document dans un bloc note, sur une
machine plutôt poussive, et malgré ça bénéficier de la force de mise en page de
LibreOffice. On s'affranchit de la plate-forme sur laquelle on travaille (on
peut éditer son fichier sous gedit sur linux, puis sur le bloc-note de
windows, et le reprendre dans un terminal via vim), et lancer la transformation
une fois le texte écrit
Vient alors la phase de mise en page, mais on est alors aidé par l'outil de
traitement de texte pour ça, et surtout, par le fait que le document généré
inclu des styles sur sa totalité, c'est donc tout de suite beaucoup plus
facile, et se fait très rapidement.
Pour ma part, c'est une solution que j'utilise et recommande, et qui au final
donne de meilleurs résultats que rst2pdf.
.. _directives: http://docutils.sourceforge.net/docs/ref/rst/directives.html
.. _meta: http://docutils.sourceforge.net/docs/user/odt.html#the-meta-directive
.. _table : http://docutils.sourceforge.net/docs/user/odt.html#the-table-directive
.. _container: http://docutils.sourceforge.net/docs/user/odt.html#the-container-directive
.. _raw: http://docutils.sourceforge.net/docs/user/odt.html#the-raw-directive
.. _ajouter la coloration syntaxique: {filename}2012-08-18-rstodt.rst
.. _AJ Cann: http://www.flickr.com/photos/ajc1/3531532114/in/photostream/
|