@nowline/cli 0.0.0-dev.20260601071750.g04bdff9

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (139) hide show
  1. package/LICENSE +190 -0
  2. package/README.md +372 -0
  3. package/dist/cli/args.d.ts +54 -0
  4. package/dist/cli/args.d.ts.map +1 -0
  5. package/dist/cli/args.js +165 -0
  6. package/dist/cli/args.js.map +1 -0
  7. package/dist/cli/formats.d.ts +61 -0
  8. package/dist/cli/formats.d.ts.map +1 -0
  9. package/dist/cli/formats.js +153 -0
  10. package/dist/cli/formats.js.map +1 -0
  11. package/dist/cli/help.d.ts +3 -0
  12. package/dist/cli/help.d.ts.map +1 -0
  13. package/dist/cli/help.js +90 -0
  14. package/dist/cli/help.js.map +1 -0
  15. package/dist/cli/output-path.d.ts +57 -0
  16. package/dist/cli/output-path.d.ts.map +1 -0
  17. package/dist/cli/output-path.js +70 -0
  18. package/dist/cli/output-path.js.map +1 -0
  19. package/dist/commands/init.d.ts +20 -0
  20. package/dist/commands/init.d.ts.map +1 -0
  21. package/dist/commands/init.js +80 -0
  22. package/dist/commands/init.js.map +1 -0
  23. package/dist/commands/render.d.ts +15 -0
  24. package/dist/commands/render.d.ts.map +1 -0
  25. package/dist/commands/render.js +436 -0
  26. package/dist/commands/render.js.map +1 -0
  27. package/dist/commands/serve.d.ts +16 -0
  28. package/dist/commands/serve.d.ts.map +1 -0
  29. package/dist/commands/serve.js +287 -0
  30. package/dist/commands/serve.js.map +1 -0
  31. package/dist/convert/parse-json.d.ts +7 -0
  32. package/dist/convert/parse-json.d.ts.map +1 -0
  33. package/dist/convert/parse-json.js +34 -0
  34. package/dist/convert/parse-json.js.map +1 -0
  35. package/dist/convert/printer.d.ts +6 -0
  36. package/dist/convert/printer.d.ts.map +1 -0
  37. package/dist/convert/printer.js +334 -0
  38. package/dist/convert/printer.js.map +1 -0
  39. package/dist/convert/schema.d.ts +33 -0
  40. package/dist/convert/schema.d.ts.map +1 -0
  41. package/dist/convert/schema.js +77 -0
  42. package/dist/convert/schema.js.map +1 -0
  43. package/dist/core/parse.d.ts +24 -0
  44. package/dist/core/parse.d.ts.map +1 -0
  45. package/dist/core/parse.js +64 -0
  46. package/dist/core/parse.js.map +1 -0
  47. package/dist/diagnostics/adapt.d.ts +6 -0
  48. package/dist/diagnostics/adapt.d.ts.map +1 -0
  49. package/dist/diagnostics/adapt.js +81 -0
  50. package/dist/diagnostics/adapt.js.map +1 -0
  51. package/dist/diagnostics/format.d.ts +18 -0
  52. package/dist/diagnostics/format.d.ts.map +1 -0
  53. package/dist/diagnostics/format.js +41 -0
  54. package/dist/diagnostics/format.js.map +1 -0
  55. package/dist/diagnostics/index.d.ts +5 -0
  56. package/dist/diagnostics/index.d.ts.map +1 -0
  57. package/dist/diagnostics/index.js +5 -0
  58. package/dist/diagnostics/index.js.map +1 -0
  59. package/dist/diagnostics/json.d.ts +8 -0
  60. package/dist/diagnostics/json.d.ts.map +1 -0
  61. package/dist/diagnostics/json.js +24 -0
  62. package/dist/diagnostics/json.js.map +1 -0
  63. package/dist/diagnostics/model.d.ts +44 -0
  64. package/dist/diagnostics/model.d.ts.map +1 -0
  65. package/dist/diagnostics/model.js +2 -0
  66. package/dist/diagnostics/model.js.map +1 -0
  67. package/dist/diagnostics/text.d.ts +6 -0
  68. package/dist/diagnostics/text.d.ts.map +1 -0
  69. package/dist/diagnostics/text.js +43 -0
  70. package/dist/diagnostics/text.js.map +1 -0
  71. package/dist/generated/templates.d.ts +4 -0
  72. package/dist/generated/templates.d.ts.map +1 -0
  73. package/dist/generated/templates.js +10 -0
  74. package/dist/generated/templates.js.map +1 -0
  75. package/dist/generated/version.d.ts +11 -0
  76. package/dist/generated/version.d.ts.map +1 -0
  77. package/dist/generated/version.js +8 -0
  78. package/dist/generated/version.js.map +1 -0
  79. package/dist/i18n/locale.d.ts +56 -0
  80. package/dist/i18n/locale.d.ts.map +1 -0
  81. package/dist/i18n/locale.js +107 -0
  82. package/dist/i18n/locale.js.map +1 -0
  83. package/dist/index.d.ts +3 -0
  84. package/dist/index.d.ts.map +1 -0
  85. package/dist/index.js +60 -0
  86. package/dist/index.js.map +1 -0
  87. package/dist/io/config.d.ts +2 -0
  88. package/dist/io/config.d.ts.map +1 -0
  89. package/dist/io/config.js +5 -0
  90. package/dist/io/config.js.map +1 -0
  91. package/dist/io/exit-codes.d.ts +12 -0
  92. package/dist/io/exit-codes.d.ts.map +1 -0
  93. package/dist/io/exit-codes.js +15 -0
  94. package/dist/io/exit-codes.js.map +1 -0
  95. package/dist/io/read.d.ts +13 -0
  96. package/dist/io/read.d.ts.map +1 -0
  97. package/dist/io/read.js +53 -0
  98. package/dist/io/read.js.map +1 -0
  99. package/dist/io/write.d.ts +32 -0
  100. package/dist/io/write.d.ts.map +1 -0
  101. package/dist/io/write.js +61 -0
  102. package/dist/io/write.js.map +1 -0
  103. package/dist/version.d.ts +13 -0
  104. package/dist/version.d.ts.map +1 -0
  105. package/dist/version.js +20 -0
  106. package/dist/version.js.map +1 -0
  107. package/man/fr/nowline.1 +463 -0
  108. package/man/fr/nowline.5 +1864 -0
  109. package/man/nowline.1 +448 -0
  110. package/man/nowline.5 +1785 -0
  111. package/package.json +70 -0
  112. package/scripts/bundle-templates.mjs +106 -0
  113. package/scripts/compile.mjs +131 -0
  114. package/src/cli/args.ts +252 -0
  115. package/src/cli/formats.ts +207 -0
  116. package/src/cli/help.ts +92 -0
  117. package/src/cli/output-path.ts +98 -0
  118. package/src/commands/init.ts +99 -0
  119. package/src/commands/render.ts +567 -0
  120. package/src/commands/serve.ts +322 -0
  121. package/src/convert/parse-json.ts +57 -0
  122. package/src/convert/printer.ts +376 -0
  123. package/src/convert/schema.ts +105 -0
  124. package/src/core/parse.ts +97 -0
  125. package/src/diagnostics/adapt.ts +89 -0
  126. package/src/diagnostics/format.ts +70 -0
  127. package/src/diagnostics/index.ts +4 -0
  128. package/src/diagnostics/json.ts +30 -0
  129. package/src/diagnostics/model.ts +48 -0
  130. package/src/diagnostics/text.ts +62 -0
  131. package/src/generated/templates.ts +13 -0
  132. package/src/generated/version.ts +18 -0
  133. package/src/i18n/locale.ts +133 -0
  134. package/src/index.ts +60 -0
  135. package/src/io/config.ts +11 -0
  136. package/src/io/exit-codes.ts +18 -0
  137. package/src/io/read.ts +70 -0
  138. package/src/io/write.ts +94 -0
  139. package/src/version.ts +21 -0
@@ -0,0 +1,463 @@
1
+ .\" Traduction française neutre. Les divergences régionales (fr-CA, fr-FR)
2
+ .\" prennent la forme de surcouches dans packages/cli/man/<locale>/nowline.1
3
+ .\" lorsqu'elles existent. Voir specs/localization.md.
4
+ .Dd $Mdocdate$
5
+ .Dt NOWLINE 1
6
+ .Os
7
+ .Sh NOM
8
+ .Nm nowline
9
+ .Nd créer des feuilles de route à partir d'un fichier texte lisible .nowline
10
+ .Sh SYNOPSIS
11
+ .Nm
12
+ .Op Fl f Ar format
13
+ .Op Fl o Ar chemin
14
+ .Op Fl t Ar thème
15
+ .Op Fl -now Ar date
16
+ .Op Ar options
17
+ .Ar entrée
18
+ .Nm
19
+ .Fl -serve
20
+ .Op Fl p Ar port
21
+ .Op Ar options
22
+ .Ar entrée
23
+ .Nm
24
+ .Fl -init
25
+ .Op Ar nom
26
+ .Nm
27
+ .Fl -dry-run
28
+ .Op Ar options
29
+ .Ar entrée
30
+ .Nm
31
+ .Op Fl V | Fl -version
32
+ .Nm
33
+ .Op Fl h | Fl -help
34
+ .Sh DESCRIPTION
35
+ .Nm
36
+ est une CLI qui traite des fichiers
37
+ .Pa .nowline
38
+ simples et lisibles qui définissent une feuille de route, et non un
39
+ diagramme de Gantt.
40
+ L'artefact principal est un SVG, mais elle génère aussi de nombreux
41
+ autres artefacts dont PNG, PDF, HTML, Markdown+Mermaid, XLSX,
42
+ MS Project XML.
43
+ .Pp
44
+ Cette page documente la CLI.
45
+ Pour le format de fichier, voir
46
+ .Xr nowline 5 .
47
+ .Sh ENTRÉE
48
+ Le format d'entrée est détecté à partir de l'extension du fichier\ :
49
+ .Pa .nowline
50
+ \(-> DSL,
51
+ .Pa .json
52
+ \(-> AST.
53
+ L'entrée standard est traitée par défaut comme
54
+ .Pa .nowline .
55
+ Utilisez
56
+ .Fl -input-format
57
+ pour les noms de fichiers inhabituels.
58
+ .Sh LANGAGE
59
+ Un fichier
60
+ .Pa .nowline
61
+ est une esquisse à indentation significative.
62
+ L'indentation canonique est de deux espaces\ ; les tabulations sont
63
+ acceptées mais ne doivent pas être mélangées avec des espaces dans un
64
+ même fichier.
65
+ Les chaînes sont entre guillemets doubles\ ; les propriétés sont des
66
+ paires
67
+ .Sy key:value .
68
+ Les commentaires utilisent
69
+ .Sq //
70
+ ou
71
+ .Sq /* */ .
72
+ .Pp
73
+ Mots-clés principaux\ :
74
+ .Bl -tag -width "person, team" -compact
75
+ .It Sy roadmap
76
+ La déclaration de feuille de route de plus haut niveau\ ; une seule
77
+ par fichier.
78
+ .It Sy swimlane
79
+ Une voie horizontale de travail (équipe, domaine, flux).
80
+ .It Sy item
81
+ Une unité de travail, indentée sous un
82
+ .Sy swimlane .
83
+ .It Sy parallel
84
+ Un bloc dont les enfants s'exécutent en simultané.
85
+ .It Sy group
86
+ Un regroupement logique d'éléments, rendus ensemble.
87
+ .It Sy anchor
88
+ Une date nommée sur la chronologie.
89
+ .It Sy milestone
90
+ Un repère ponctuel qui dépend d'un travail.
91
+ .It Sy person , team
92
+ Vocabulaire d'organisation référencé par
93
+ .Sy owner: .
94
+ .It Sy label
95
+ Étiquette réutilisable référencée par
96
+ .Sy labels: .
97
+ .El
98
+ .Pp
99
+ Chaque entité suit une forme universelle\ :
100
+ .Bd -literal -offset indent
101
+ keyword [id] ["title"] [key:value ...]
102
+ .Ed
103
+ .Pp
104
+ Au moins un identifiant
105
+ .Ar id
106
+ ou un titre
107
+ .Qq Ar title
108
+ est requis \(em l'analyseur les distingue par les guillemets.
109
+ .Pp
110
+ Exemple minimal\ :
111
+ .Bd -literal -offset indent
112
+ nowline v1
113
+ roadmap r "Demo" start:2026-01-06
114
+ swimlane platform
115
+ item research "Research" duration:3w
116
+ item build "Build" duration:2w
117
+ .Ed
118
+ .Pp
119
+ Voir
120
+ .Xr nowline 5
121
+ .Pq Sy man 5 nowline
122
+ pour la grammaire complète, toutes les propriétés, les règles de
123
+ validation et les déclarations
124
+ .Sy include
125
+ / config / style.
126
+ .Sh INDICATEURS DE MODE
127
+ Les indicateurs de mode ci-dessous sont mutuellement exclusifs.
128
+ .Bl -tag -width Fl
129
+ .It Fl -serve
130
+ Lance un serveur de prévisualisation locale avec rechargement
131
+ automatique.
132
+ Réanalyse, revalide, refait la mise en page et reproduit à chaque
133
+ modification du fichier\ ; les navigateurs connectés rafraîchissent
134
+ via Server-Sent Events.
135
+ Les erreurs de validation s'affichent en surimpression sur le dernier
136
+ rendu réussi.
137
+ L'option
138
+ .Fl o Ar chemin
139
+ écrit également le résultat sur le disque à chaque reconstruction.
140
+ .It Fl -init Op Ar nom
141
+ Crée un fichier
142
+ .Pa .nowline
143
+ de démarrage dans le répertoire courant.
144
+ L'argument positionnel est le
145
+ .Em nom
146
+ du projet, et non un chemin\ ;
147
+ .Pa .nowline
148
+ est ajouté automatiquement s'il manque.
149
+ Le nom par défaut est
150
+ .Sy roadmap .
151
+ Les fichiers existants sont écrasés sans confirmation.
152
+ .It Fl n , -dry-run
153
+ Exécute la totalité du pipeline (analyse + validation + mise en page +
154
+ format) sans écrire de fichier.
155
+ Remplace l'ancien verbe
156
+ .Sy validate .
157
+ Termine avec 0 en cas de succès, 1 en cas d'erreur de validation.
158
+ Compatible avec tous les formats de sortie\ —
159
+ .Nm Ar feuille.nowline Fl f Ar pdf Fl -dry-run
160
+ exerce tout le pipeline PDF sans produire de fichier.
161
+ .El
162
+ .Sh OPTIONS D'E/S
163
+ .Bl -tag -width Fl
164
+ .It Fl f , -format Ar fmt
165
+ Format de sortie\ :
166
+ .Sy svg , png , pdf , html , mermaid , xlsx , msproj , json , nowline .
167
+ Par défaut\ : déduit de l'extension de
168
+ .Fl o ,
169
+ sinon
170
+ .Pa .nowlinerc
171
+ .Sy defaultFormat ,
172
+ sinon
173
+ .Sy svg .
174
+ .It Fl o , -output Ar chemin
175
+ Chemin du fichier de sortie.
176
+ Utilisez
177
+ .Sq -
178
+ pour la sortie standard (convention Unix du tiret).
179
+ Par défaut\ :
180
+ .Pa <cwd>/<base-entrée>.<format> .
181
+ Les fichiers existants sont écrasés sans confirmation.
182
+ .It Fl -input-format Ar fmt
183
+ Force le format d'entrée\ :
184
+ .Sy nowline | json .
185
+ Par défaut\ : déduit de l'extension\ ; l'entrée standard est traitée
186
+ comme
187
+ .Sy nowline .
188
+ .El
189
+ .Sh OPTIONS DE PRODUCTION
190
+ .Bl -tag -width Fl
191
+ .It Fl t , -theme Ar nom
192
+ .Sy light | dark .
193
+ .It Fl -now Ar date
194
+ Ancrage
195
+ .Sq Maintenant
196
+ pour la ligne de temps présent et le calcul des dates, au format
197
+ .Pa AAAA-MM-JJ .
198
+ Par défaut\ : aujourd'hui (date civile UTC du système).
199
+ Indiquez
200
+ .Fl -now Sq -
201
+ pour supprimer entièrement la ligne de temps présent.
202
+ .It Fl -locale Ar bcp47
203
+ Étiquette de langue BCP-47 pour les messages CLI de l'opérateur
204
+ (diagnostics de validation sur la sortie d'erreur,
205
+ .Fl -help ,
206
+ erreurs d'analyse, journaux verbeux).
207
+ Exemples\ :
208
+ .Sy en-US , fr , fr-CA , fr-FR .
209
+ .Pp
210
+ Nowline maintient deux chaînes de locale indépendantes pour qu'un
211
+ opérateur francophone puisse lire les erreurs en français tout en
212
+ produisant une feuille de route anglaise rédigée par un collègue
213
+ américain (et inversement)\ :
214
+ .Bl -tag -width Ds
215
+ .It Em Locale du contenu Pq inscrite dans le SVG / PDF / etc. produit
216
+ Directive
217
+ .Sy nowline v1 locale:
218
+ du fichier
219
+ \(->
220
+ .Fl -locale
221
+ \(->
222
+ .Ev LC_ALL Ns / Ns Ev LC_MESSAGES Ns / Ns Ev LANG
223
+ \(->
224
+ .Sy en-US .
225
+ Le fichier l'emporte toujours\ ; la locale de l'opérateur ne sert
226
+ de repli que si le fichier ne déclare pas la sienne.
227
+ .It Em Locale de l'opérateur Pq messages stderr / stdout
228
+ .Fl -locale
229
+ \(->
230
+ .Ev LC_ALL Ns / Ns Ev LC_MESSAGES Ns / Ns Ev LANG
231
+ \(->
232
+ .Sy en-US .
233
+ Indépendante de la directive du fichier\ : un
234
+ .Ev LANG
235
+ français maintient les erreurs de validation en français même si
236
+ le fichier indique
237
+ .Sy locale:en-US .
238
+ .El
239
+ .Pp
240
+ Les bundles de traduction redescendent la chaîne BCP-47
241
+ .Pq Sy fr-CA No \(-> Sy fr No \(-> Sy en-US ,
242
+ de sorte que les entrées manquantes sont silencieusement complétées.
243
+ Voir
244
+ .Pa specs/localization.md
245
+ pour la matrice de résolution.
246
+ .It Fl -no-links
247
+ Omet les icônes de lien dans les éléments produits.
248
+ .It Fl s , -scale Ar n
249
+ Facteur d'échelle pour le rendu raster (PNG uniquement\ ; 1 par défaut).
250
+ .It Fl -strict
251
+ Promeut les avertissements (assets, sanitiseur) en erreurs.
252
+ .It Fl w , -width Ar px
253
+ Largeur du canevas en pixels (1280 par défaut).
254
+ .It Fl -asset-root Ar dossier
255
+ Dossier à partir duquel les ressources logo / image peuvent être
256
+ chargées (par défaut\ : dossier du fichier d'entrée).
257
+ .El
258
+ .Sh OPTIONS SPÉCIFIQUES AU FORMAT
259
+ .Bl -tag -width Fl
260
+ .It Fl -page-size Ar taille
261
+ Taille de page PDF\ : préréglage
262
+ .Pq Sy letter , legal , tabloid , ledger , a1 No \(en Sy a5 , b3 No \(en Sy b5 ,
263
+ .Sy content
264
+ pour ajustement automatique, ou
265
+ .Sy LxH Ns Em unité
266
+ pour une taille personnalisée (p.\ ex.
267
+ .Sy 8.5x11in , 210x297mm ) .
268
+ Par défaut\ :
269
+ .Sy letter .
270
+ .It Fl -orientation Ar nom
271
+ Orientation PDF\ :
272
+ .Sy portrait | landscape | auto .
273
+ Par défaut\ :
274
+ .Sy auto .
275
+ .It Fl -margin Ar longueur
276
+ Marge de page PDF.
277
+ Les nombres seuls sont en points\ ; les suffixes
278
+ .Pq Sy in , mm , cm
279
+ sont acceptés.
280
+ Par défaut\ :
281
+ .Sy 36pt
282
+ (1/2 pouce).
283
+ .It Fl -font-sans Ar réf
284
+ Police sans-serif pour PNG/PDF\ : chemin TTF/OTF, ou alias
285
+ .Pq Sy sf , helvetica , dejavu , ... .
286
+ Par défaut\ : sondage de la plateforme \(-> repli sur DejaVu intégré.
287
+ .It Fl -font-mono Ar réf
288
+ Police monospace pour PNG/PDF\ ; même chaîne de résolution que
289
+ .Fl -font-sans .
290
+ .It Fl -headless
291
+ Saute le sondage de polices de la plateforme et force la paire DejaVu
292
+ intégrée.
293
+ La sortie est stable octet par octet entre machines.
294
+ .It Fl -start Ar date
295
+ MS Project\ : date d'ancrage
296
+ .Pq Pa AAAA-MM-JJ
297
+ pour les feuilles de route uniquement relatives.
298
+ Par défaut\ :
299
+ .Fl -now ,
300
+ puis repli déterministe.
301
+ .El
302
+ .Sh OPTIONS DE SERVEUR
303
+ .Bl -tag -width Fl
304
+ .It Fl p , -port Ar n
305
+ Port d'écoute (4318 par défaut).
306
+ .It Fl -host Ar hôte
307
+ Adresse de liaison (par défaut
308
+ .Sy 127.0.0.1 ;
309
+ utilisez
310
+ .Sy 0.0.0.0
311
+ pour exposer sur le réseau local).
312
+ .It Fl -open
313
+ Ouvre le navigateur au démarrage.
314
+ .El
315
+ .Sh OPTIONS DE JOURNALISATION
316
+ Les indicateurs de journalisation sont mutuellement exclusifs.
317
+ .Bl -tag -width Fl
318
+ .It Fl v , -verbose
319
+ Affiche des diagnostics supplémentaires sur la sortie d'erreur standard
320
+ (chemin de configuration, durées du pipeline, résolution des polices,
321
+ décisions de repli).
322
+ .It Fl q , -quiet
323
+ Supprime les messages non liés aux erreurs sur la sortie d'erreur
324
+ standard.
325
+ .El
326
+ .Sh OPTIONS STANDARD
327
+ .Bl -tag -width Fl
328
+ .It Fl h , -help
329
+ Affiche l'aide sur la sortie standard et termine avec 0.
330
+ .It Fl V , -version
331
+ Affiche la version sur la sortie standard et termine avec 0.
332
+ .El
333
+ .Pp
334
+ .Fl V
335
+ (majuscule) correspond à
336
+ .Fl -version ,
337
+ tandis que la minuscule
338
+ .Fl v
339
+ correspond à
340
+ .Fl -verbose ,
341
+ suivant
342
+ .Xr curl 1
343
+ et
344
+ .Xr ssh 1 .
345
+ .Sh ENVIRONNEMENT
346
+ .Bl -tag -width Ev
347
+ .It Ev LC_ALL , LC_MESSAGES , LANG
348
+ Locale de repli pour l'opérateur lorsque
349
+ .Fl -locale
350
+ est absent.
351
+ La première variable non vide l'emporte, dans l'ordre indiqué.
352
+ Les suffixes POSIX
353
+ .Pq Sq .UTF-8 , Sq @euro
354
+ sont retirés et le résultat est normalisé en BCP-47.
355
+ .Pp
356
+ Affecte sans condition la chaîne opérateur
357
+ .Pq stderr / stdout, diagnostics de validation, --help, erreurs, journaux verbeux .
358
+ N'affecte la chaîne contenu
359
+ .Pq libellés d'axe rendus, pastille « maintenant », préfixe trimestriel
360
+ que si le fichier ne déclare pas sa propre directive
361
+ .Sy nowline v1 locale: \(em
362
+ le fichier l'emporte toujours pour l'artefact produit.
363
+ Voir
364
+ .Pa specs/localization.md
365
+ pour la matrice de résolution.
366
+ .El
367
+ .Sh FICHIERS
368
+ .Bl -tag -width Pa
369
+ .It Pa .nowlinerc
370
+ Fichier de configuration JSON ou YAML facultatif.
371
+ Recherché en remontant depuis le dossier du fichier d'entrée\ ; le plus
372
+ proche l'emporte.
373
+ Les indicateurs CLI surclassent les valeurs de configuration.
374
+ Clés reconnues\ :
375
+ .Sy theme , defaultFormat , width , pdfPageSize , pdfOrientation ,
376
+ .Sy pdfMargin , fontSans , fontMono , headlessFonts , locale .
377
+ Les clés inconnues sont ignorées.
378
+ .El
379
+ .Sh CODES DE SORTIE
380
+ .Bl -tag -width Ds
381
+ .It 0
382
+ Succès.
383
+ .It 1
384
+ Erreur de validation (analyse en échec, référence invalide, etc.).
385
+ .It 2
386
+ Erreur d'utilisation (entrée manquante, indicateurs incorrects ou
387
+ mutuellement exclusifs, format non pris en charge, fichier introuvable,
388
+ sortie binaire vers un terminal, entrée illisible).
389
+ .It 3
390
+ Erreur de sortie (impossible d'écrire à la destination, échec du
391
+ pipeline d'export).
392
+ .El
393
+ .Sh EXEMPLES
394
+ Produire le SVG par défaut dans le dossier courant\ :
395
+ .Bd -literal -offset indent
396
+ nowline feuille.nowline
397
+ .Ed
398
+ .Pp
399
+ Produire dans un autre format\ ; le format est déduit de l'extension de
400
+ .Fl o \ :
401
+ .Bd -literal -offset indent
402
+ nowline feuille.nowline -f pdf
403
+ nowline feuille.nowline -o feuille.pdf
404
+ nowline feuille.nowline -f png --scale 3
405
+ .Ed
406
+ .Pp
407
+ Diffuser le SVG vers la sortie standard, valider et prévisualiser en
408
+ direct\ :
409
+ .Bd -literal -offset indent
410
+ nowline feuille.nowline -o -
411
+ nowline feuille.nowline --dry-run
412
+ nowline feuille.nowline --serve -p 8080
413
+ .Ed
414
+ .Pp
415
+ Lire l'entrée standard\ ; convertir entre texte et JSON AST\ :
416
+ .Bd -literal -offset indent
417
+ cat feuille.nowline | nowline -
418
+ nowline feuille.nowline -f json -o feuille.json
419
+ nowline feuille.json -f nowline -o feuille.nowline
420
+ .Ed
421
+ .Pp
422
+ Créer un nouveau fichier\ :
423
+ .Bd -literal -offset indent
424
+ nowline --init
425
+ nowline --init mon-projet
426
+ .Ed
427
+ .Pp
428
+ PDF avec géométrie de page explicite, stable octet pour octet entre
429
+ machines\ :
430
+ .Bd -literal -offset indent
431
+ nowline feuille.nowline -f pdf --page-size a4 \\
432
+ --orientation landscape --margin 0.5in --headless
433
+ .Ed
434
+ .Pp
435
+ Lire les erreurs et diagnostics en français tout en produisant
436
+ l'artefact dans la locale déclarée par le fichier\ :
437
+ .Bd -literal -offset indent
438
+ nowline feuille.nowline --locale fr-CA
439
+ .Ed
440
+ .Pp
441
+ Fixer la locale de l'artefact produit au niveau du fichier pour
442
+ qu'elle reste française quel que soit l'opérateur qui exécute
443
+ .Nm \ :
444
+ .Bd -literal -offset indent
445
+ nowline v1 locale:fr-CA
446
+ .Ed
447
+ .Sh VOIR AUSSI
448
+ .Lk https://github.com/lolay/nowline "Code source, suivi des incidents et référence DSL complète"
449
+ .Pp
450
+ Le dossier
451
+ .Sy specs/
452
+ du dépôt source documente la grammaire DSL
453
+ .Pq Pa specs/dsl.md ,
454
+ le pipeline de mise en page et de production
455
+ .Pq Pa specs/rendering.md ,
456
+ la surface CLI
457
+ .Pq Pa specs/cli.md ,
458
+ les jalons libres
459
+ .Pq Pa specs/milestones.md
460
+ et le modèle de localisation
461
+ .Pq Pa specs/localization.md .
462
+ .Sh AUTEURS
463
+ .An Les Auteurs de Nowline Aq Mt maintainers@nowline.io