]> git.donarmstrong.com Git - lilypond.git/blob - Documentation/fr/usage/running.itely
Rerun scripts/auxiliar/update-with-convert-ly.sh
[lilypond.git] / Documentation / fr / usage / running.itely
1 @c -*- coding: utf-8; mode: texinfo; documentlanguage: fr -*-
2
3 @ignore
4     Translation of GIT committish: eea3764cd6bbc78506261f78ed4e7745ac69df41
5
6     When revising a translation, copy the HEAD committish of the
7     version that you are working on.  For details, see the Contributors'
8     Guide, node Updating translation committishes..
9 @end ignore
10
11 @c \version "2.17.6"
12
13 @c Translators: Jean-Charles Malahieude
14 @c Translation checkers:
15
16 @node Exécution de lilypond
17 @chapter Exécution de @command{lilypond}
18 @translationof Running lilyPond
19
20 Ce chapitre passe en revue ce qui se passe lorsque vous lancez LilyPond.
21
22 @menu
23 * Utilisation habituelle::
24 * Utilisation en ligne de commande::
25 * Messages d'erreur::
26 * Quelques erreurs des plus courantes::
27 @end menu
28
29 @node Utilisation habituelle
30 @section Utilisation habituelle
31 @translationof Normal usage
32
33 La plupart des utilisateurs de LilyPond le font au travers d'une
34 interface graphique (@emph{GUI} pour @emph{graphical user interface}).
35 Si vous ne l'avez pas encore parcouru, lisez le @rlearning{Tutoriel}.
36 Si vous utilisez un éditeur alternatif pour rédiger vos fichiers
37 LilyPond, référez-vous à la documentation de celui-ci.
38
39
40 @node Utilisation en ligne de commande
41 @section Utilisation en ligne de commande
42 @translationof Command-line usage
43
44 Nous nous intéresserons ici aux spécificités de LilyPond employé en
45 ligne de commande.  La ligne de commande permet de faire appel à
46 certaines options particulières.  D'autre part, certains utilitaires
47 associés, tel que @code{midi2ly}, ne sont disponibles qu'en ligne de
48 commande.
49
50 Par @qq{ligne de commande}, nous entendons l'interface de commande du
51 système.  Les utilisateurs de Windows seront certainement plus familiers
52 des termes @qq{fenêtre DOS} ou @qq{invite de commande}.  Quant aux
53 utilisateurs de MacOS X, ils connaissent assurément les termes
54 @qq{console} et @qq{terminal}.  Les paramétrages spécifiques au système
55 MacOS font l'objet d'un @rwebnamed{MacOS X,chapitre particulier}.
56
57 Notre propos n'est pas ici d'expliquer ce qu'est l'interface de
58 commande pour un système informatique ni comment elle fonctionne.
59 Aussi, si vous ne savez de quoi il retourne, nous vous renvoyons aux
60 nombreuses documentations que vous pourrez trouver sur ce sujet.
61
62 @menu
63 * Lancement de lilypond::
64 * Options basiques de lilypond::
65 * Options avancées de lilypond::
66 * Variables d'environnement::
67 * Exécution de LilyPond en mode protégé::
68 @end menu
69
70
71 @node Lancement de lilypond
72 @unnumberedsubsec Lancement de @command{lilypond}
73 @translationof Invoking lilypond
74
75 L'exécutable @command{lilypond} en ligne de commande se lance ainsi :
76
77 @example
78 lilypond [@var{option}]@dots{} @var{fichier}@dots{}
79 @end example
80
81 Lorsque le fichier est fourni sans extension, LilyPond présume qu'il
82 s'agit de @file{.ly}.  Pour interpréter directement l'entrée standard
83 (@emph{stdin}), fournissez un tiret (@code{-}) en lieu et place de
84 @var{fichier}.
85
86 Le traitement de @file{monfichier.ly} produira @file{monfichier.ps} et
87 @file{monfichier.pdf}.  Vous pouvez spécifier plusieurs fichiers à la
88 fois ; ils seront traités indépendamment les uns des
89 autres.@footnote{Le statut de GUILE n'étant pas réinitialisé après
90 traitement d'un fichier @file{.ly}, veillez à ne pas modifier les
91 réglages par défaut du système à partir d'assertions en Scheme.}
92
93 Lorsque @file{monfichier.ly} contient plus d'une section @code{\book},
94 les fichiers produits -- à partir du deuxième -- seront numérotés.  Par
95 ailleurs, la valeur affectée à @code{output-suffix} sera insérée entre la
96 racine et le numéro.  Par exemple, un fichier @var{racine} qui
97 contiendrait
98
99 @example
100 #(define output-suffix "violon")
101 \score @{ @dots{} @}
102 #(define output-suffix "cello")
103 \score @{ @dots{} @}
104 @end example
105
106 @noindent
107 fournira grâce à LilyPond @file{@var{racine}-violon.pdf} et
108 @file{@var{racine}-cello-1.pdf}.
109
110
111 @unnumberedsubsubsec Commandes standard de l'interpréteur
112 @translationof Standard shell commands
113
114 Si votre interpréteur -- terminal, console, etc. -- prend en charge les
115 redirections, les commandes qui suivent vous permettront de
116 judicieusement rediriger les affichages de la console dans un
117 fichier :
118
119 @itemize
120
121 @item
122 @code{lilypond fichier.ly 1>stdout.log} pour le verbiage normal
123
124 @item
125 @code{lilypond fichier.ly 2>stderr.log} pour les messages d'erreur
126
127 @item
128 @code{lilypond fichier.ly &>tous.log} pour garder une trace de tout ce
129 qui s'est passé
130
131 @end itemize
132
133 Consultez avant tout la documentation de votre interpréteur habituel
134 pour vérifier qu'il prend en charge ces options dans cette syntaxe.
135 Notez bien qu'il s'agit ici de commandes internes à l'interpréteur et
136 qui n'ont rien à voir avec LilyPond.
137
138
139 @node Options basiques de lilypond
140 @unnumberedsubsec Options basiques de @command{lilypond}
141 @translationof Basic command line options for LilyPond
142
143 @cindex lancement de @command{lilypond}
144 @cindex ligne de commande, options pour @command{lilypond}
145 @cindex options, ligne de commande
146 @cindex switches
147 @cindex commutateurs
148
149 Différentes options sont disponibles en ligne de commande :
150
151 @table @code
152
153 @item -d,--define-default=@var{variable}=@var{valeur}
154 Voir @ref{Options avancées de lilypond}.
155
156 @cindex Scheme, évaluation d'expression
157 @cindex expression Scheme, évaluation
158 @item -e,--evaluate=@var{expr}
159 Évalue l'expression Scheme @var{expr} avant d'analyser tout fichier
160 @file{.ly}.  Lorsque vous spécifiez l'option @option{-e} à plusieurs
161 reprises, l'évaluation sera faite en séquence.
162
163 Dans la mesure où l'expression est évaluée par le module
164 @code{guile-user}, vous devrez, dès lors que @var{expr} utilise des
165 définitions, spécifier
166
167 @example
168 lilypond -e '(define-public a 42)'
169 @end example
170
171 @noindent
172 en ligne de commande, et ajouter la ligne
173
174 @example
175 #(use-modules (guile-user))
176 @end example
177
178 @noindent
179 en tête de votre fichier @file{.ly}.
180
181 @warning{Les utilisateurs de Windows doivent utiliser des guillemets
182 doubles @code{"} en lieu et place des guillemets simples @code{'}.}
183 @c Match " in context-sensitive editors
184
185 @cindex sortie, format
186 @cindex format de sortie
187 @item -f,--format=@var{format}
188 Détermine le format à produire.  Il peut s'agir de @code{ps}, @code{pdf}
189 ou @code{png}.
190
191 Exemple : @code{lilypond -fpng @var{monfichier}.ly}
192
193 @item -h,--help
194 Affiche un résumé des commandes.
195
196 @item -H,--header=@var{CHAMP}
197 Recopie le champ d'entête dans le fichier @file{RACINE.@var{CHAMP}}.
198
199 @item -i,--init=@var{fichier}
200 Définit @var{fichier} (par défaut @file{init.ly}) en tant que fichier
201 d'initialisation.
202
203 @cindex recherche de fichier
204 @cindex chemin de recherche
205 @item -I,--include=@var{répertoire}
206 Ajoute @var{répertoire} au chemin de recherche pour les inclusions.
207
208 Vous pouvez mentionner plusieurs fois l'option @option{-I}, auquel cas
209 la recherche commencera dans le premier répertoire inclus et, si le
210 fichier en question ne s'y trouve pas, les répertoires suivants seront
211 examinés l'un après l'autre.
212
213 @cindex chroot jail, fonctionnement
214 @item -j,--jail=@var{user},@var{group},@var{jail},@var{dir}
215 Lance @command{lilypond} dans un environnement protégé.
216
217 L'option @option{--jail} est une alternative qui offre plus de
218 flexibilité que l'option @option{--safe} lorsque LilyPond est installé
219 sur un serveur web ou traite des fichiers externes -- voir
220 @ref{Options avancées de lilypond}.
221
222 L'option @option{--jail} va détourner la racine de @command{lilypond}
223 sur @var{jail} juste avant d'effectuer la compilation à proprement
224 parler.  L'utilisateur et le groupe sont modifiés en conséquence, et le
225 répertoire en cours devient @var{dir}.  Ces réglages assurent -- du
226 moins en théorie -- l'impossibilité de s'échapper de la cellule.  Notez
227 cependant que, pour que l'option @option{--jail} soit fonctionnelle,
228 @command{lilypond} doit être lancé en tant qu'administrateur -- ce qui
229 se réalise aisément à l'aide de la commande @command{sudo}.
230
231 La création d'un environnement sécurisé requiert quelques précautions
232 dans la mesure où LilyPond doit disposer de tout ce dont il a besoin
233 pour compiler le fichier source @strong{à l'intérieur de la cellule}.
234 L'ermitage, avant d'être viable, requiert donc les étapes
235 suivantes :
236
237 @table @asis
238
239 @item Création d'un système de fichiers indépendant
240 L'intérêt d'un système de fichiers dédié à LilyPond réside dans le fait
241 qu'on peut le brider à l'aide des options @code{noexec}, @code{nodev} et
242 @code{nosuid}.  Il sera de fait impossible de lancer des exécutables ou
243 d'écrire sur un périphérique à partir de LilyPond.  Si vous n'avez pas
244 l'intention de créer un tel système sur une partition séparée, vous
245 pouvez avoir recours à un pseudo-périphérique (@emph{loop device}) monté
246 à partir d'un simple fichier de taille raisonnable.  D'autre part, le
247 recours à un système de fichiers indépendant permet de limiter l'espace
248 dévolu à LilyPond.
249
250 @item Création d'un utilisateur spécifique
251 L'utilisation de LilyPond au sein de la cellule devrait être réservé à
252 un utilisateur aux droits restreints.  Il faudra donc créer un
253 utilisateur et un groupe spécifiques -- disons
254 @w{@code{lily}/@code{lily}} -- qui n'aura accès en écriture qu'à un
255 unique répertoire déterminé par la valeur de @var{dir}.
256
257 @item Agencement des lieux
258 LilyPond a besoin d'un certain nombre de fichiers pour pouvoir tourner
259 correctement.  Ces fichiers devront donc tous se retrouver dans
260 l'environnement protégé, distribués selon la même arborescence que dans
261 le système d'origine.  Ainsi l'intégralité de l'installation de LilyPond
262 (en principe @file{/usr/share/lilypond}) doit y être dupliquée.
263
264 En cas de problème, lancer LilyPond en utilisant @command{strace}
265 devrait vous permettre de déterminer quels fichiers manquent à l'appel.
266
267 @item Lancement de LilyPond
268 Dans un environnement protégé monté avec l'option @code{noexec}, il
269 est impossible de lancer un quelconque programme extérieur.  LilyPond ne
270 saurait donc avoir recours à un moteur de traitement qui le mettrait
271 dans cette situation.  Comme nous l'avons vu plus haut, LilyPond sera
272 lancé avec les privilèges de l'administrateur -- privilèges qu'il perdra
273 aussitôt --, ce qui peut nécessiter le recours à la commande
274 @code{sudo}.  Il est par ailleurs judicieux de limiter le temps
275 processeur alloué à LilyPond -- grâce à @command{ulimit -t} par
276 exemple -- ainsi que, si votre système le permet, la taille de la
277 mémoire.  Voir aussi @ref{Exécution de LilyPond en mode protégé}.
278 @end table
279
280 @cindex loglevel
281 @cindex verbosité, définir le degré de
282 @item -l,--loglevel=@var{DEGRÉ}
283 Règle le niveau de verbosité des messages console à @var{DEGRÉ}.  Les
284 différentes valeurs sont :
285
286 @table @code
287 @item NONE
288 Aucun verbiage, même pas les messages d'erreur.
289
290 @item ERROR
291 Uniquement les messages d'erreur ; pas de message d'avertissement
292 ni de progression.
293
294 @item WARN
295 Messages d'avertissement ou d'erreur ; pas d'information de
296 progression.
297
298 @item BASIC_PROGRESS
299 Information de progression basique (réussite) et avertissements ou
300 erreurs.
301
302 @item PROGRESS
303 Toutes les informations de progression, avertissements et erreurs.
304
305 @item INFO (par défaut)
306 Informations de progression, avertissements et erreurs, ainsi que
307 d'autres informations relatives à l'exécution.
308
309 @item DEBUG
310 Tout ce qui peut être affiché, y compris le verbiage utile au débogage.
311
312 @end table
313
314 @cindex redirection
315 @cindex répertoire de destination
316 @cindex fichier de destination
317 @item -o,--output=@var{FICHIER} ou @var{RÉPERTOIRE}
318 Détermine le nom par défaut du fichier résultant à @var{FICHIER} ;
319 lorsque l'argument @var{RÉPERTOIRE} correspond à un répertoire déjà
320 existant, c'est là que les fichiers résultants seront déposés.  Le
321 suffixe adéquat sera ajouté (par ex. @code{.pdf} pour du pdf) dans tous
322 les cas.
323
324 @cindex PostScript, output
325 @cindex PS (PostScript), output
326 @item --ps
327 Génère du PostScript.
328
329 @cindex Portable Network Graphics (PNG), output
330 @cindex PNG (Portable Network Graphics), output
331 @item --png
332 Génère une image par page, au format PNG ; ceci sous-entend
333 l'utilisation de @option{--ps}.  La résolution de l'image, en DPI, peut
334 se régler en ajoutant par exemple
335 @example
336 -dresolution=110
337 @end example
338
339 @cindex Portable Document Format (PDF), output
340 @cindex PDF (Portable Document Format), output
341 @item --pdf
342 Génère du PDF.  Ceci sous-entend l'utilisation de @option{--ps}.
343
344 @item -v,--version
345 Affiche le numéro de version.
346
347 @item -V,--verbose
348 Active le mode verbeux : affichage de l'intégralité du chemin
349 d'accès de chaque fichier, et information des temps de traitement.
350
351 @item -w,--warranty
352 Affiche les informations de garantie applicables à GNU LilyPond -- il
353 est livré @strong{SANS GARANTIE} !
354
355 @end table
356
357
358 @node Options avancées de lilypond
359 @unnumberedsubsec Options avancées de @command{lilypond}
360 @translationof Advanced command line options for LilyPond
361
362 @table @code
363
364 @item -d@var{[nom-option]}=@var{[valeur]},--define-default=@var{[nom-option]}=@var{[valeur]}
365 Affecte la valeur Scheme @var{valeur} à l'option interne
366 @var{nom-option} du programme.  En l'absence de @var{valeur}, le
367 programme utilisera @var{#t}. Préfixer @var{nom-option} d'un @code{no-}
368 vous permet de désactiver une option.  Ainsi,
369
370 @cindex point and click, ligne de commande
371 @cindex pointer-cliquer, ligne de commande
372
373 @example
374 -dno-point-and-click
375 @end example
376
377 @noindent
378 revient au même que
379 @example
380 -dpoint-and-click=#f
381 @end example
382 @end table
383
384 @noindent Voici les différentes options disponibles, ainsi que leur
385 valeur par défaut.
386
387 @multitable @columnfractions .33 .16 .51
388 @item @strong{Symbole}
389 @tab @strong{Valeur}
390 @tab @strong{Observations}
391
392
393 @item @code{anti-alias-factor}
394 @tab @code{1}
395 @tab Adopte une résolution supérieure (selon le facteur donné),puis
396 réduit au niveau du résultat afin d'éviter les @qq{distorsions} des
397 images @code{PNG}.
398
399 @item @code{aux-files}
400 @tab @code{#t}
401 @tab Génère les fichiers @code{.tex}, @code{.texi} et @code{.count}
402 pour le moteur de rendu @code{EPS}.
403
404 @item @code{backend}
405 @tab @code{'ps}
406 @tab Détermine le format de sortie à utiliser par le moteur de
407 traitement.  Les fichiers PostScript (format par défaut) incluent les
408 fontes @code{TTF}, @code{Type1} et @code{OTF}, et aucune substitution ne
409 sera opérée pour ces fontes.  Si vous utilisez des jeux de caractères
410 orientaux, le fichier aura vite fait d'atteindre une taille conséquente.
411
412 @item
413 @tab @code{'eps}
414 @tab Génère du PostScript encapsulé.  Chaque page (système) fera l'objet
415 d'un fichier @file{EPS} particulier, sans fontes, auquel sera associé un
416 fichier @file{EPS} qui, lui, contiendra toutes les pages (systèmes) et
417 les fontes.  Notez qu'il s'agit du mode que @command{lilypond-book}
418 utilise par défaut.
419
420 @item
421 @tab @code{'null}
422 @tab Ne génère aucun fichier imprimable.  Cette option est équivalente à
423 @code{-dno-print-pages}.
424
425 @item
426 @tab @code{'svg}
427 @tab Génère du@emph{Scalable Vector Graphics}.  Cette option permet de
428 créer un fichier @code{SVG} par page, sans incorporation des fontes.
429 Nous vous recommandons d'installer les fontes Century Schoolbook
430 comprises dans le paquetage LilyPond afin d'obtenir le meilleur rendu
431 possible.  Sous UNIX, il suffit de les recopier, à partir du répertoire
432 @file{/usr/share/lilypond/VERSION/fonts/otf/}, dans @file{~/.fonts/}.
433 Les fichiers @code{SVG} alors générés devraient être lisibles par votre
434 éditeur SVG habituel.  L'option @code{svg-woff} -- voir ci-après --
435 permet d'utiliser les fontes @code{woff} avec le moteur @code{SVG}.
436
437 @item
438 @tab @code{'scm}
439 @tab Recopie littéralement les commandes Scheme internes de formatage.
440
441 @item @code{check-internal-types}
442 @tab @code{#f}
443 @tab Vérifie qu'à chaque propriété est bien affecté un type.
444
445 @item @code{clip-systems}
446 @tab @code{#f}
447 @tab Génère des typons à partir d'une partition.
448
449 @item @code{datadir}
450 @tab
451 @tab Détermine le préfixe des fichiers de données (lecture seule).
452
453 @item @code{debug-gc}
454 @tab @code{#f}
455 @tab Génère une copie brute de la mémoire, aux fins de débogage.
456
457 @item @code{debug-gc-assert-parsed-dead}
458 @tab @code{#f}
459 @tab Pour débogage de la mémoire : s'assure que toute référence à
460 des objets analysés est effacée.  Il s'agit d'une option interne qui
461 est automatiquement activée par l'option @code{`-ddebug-gc'}.
462
463 @item @code{debug-lexer}
464 @tab @code{#f}
465 @tab Débogage de l'analyseur lexical @emph{flex}.
466
467 @item @code{debug-page-breaking-scoring}
468 @tab @code{#f}
469 @tab Purge les calculs des configurations de saut de page.
470
471 @item @code{debug-parser}
472 @tab @code{#f}
473 @tab Débogage de l'analyseur @emph{bison}.
474
475 @item @code{debug-property-callbacks}
476 @tab @code{#f}
477 @tab Débogage des chaînes de @emph{callback} cycliques.
478
479 @item @code{debug-skylines}
480 @tab @code{#f}
481 @tab Débogage des lignes d'horizon.
482
483 @item @code{delete-intermediate-files}
484 @tab @code{#t}
485 @tab Supprime les fichiers @code{.ps} inutiles crées lors de la
486 compilation.
487
488 @item @code{dump-cpu-profile}
489 @tab @code{#f}
490 @tab Génère une copie brute des informations de timing (dépend du
491 système).
492
493 @item @code{dump-profile}
494 @tab @code{#f}
495 @tab Génère une copie brute de la mémoire et des temps de traitement
496 pour chaque fichier.
497
498 @item @code{dump-signatures}
499 @tab @code{#f}
500 @tab Génère une copie des signatures de chaque système.  Cette option
501 est utilisée pour les tests de régression.
502
503 @item @code{eps-box-padding}
504 @tab @code{#f}
505 @tab Décale le bord gauche du typon EPS d'une valeur donnée en
506 millimètres.
507
508 @item @code{gs-load-fonts}
509 @tab @code{#f}
510 @tab Charge les fontes grâce à Ghostscript.
511
512 @item @code{gs-load-lily-fonts}
513 @tab @code{#f}
514 @tab Limite les fontes chargées par Ghostscript aux seules fontes
515 LilyPond.
516
517 @item @code{gui}
518 @tab @code{#f}
519 @tab Travaille silencieusement, et redirige tout le verbiage dans un
520 fichier journal.
521 @end multitable
522
523 @noindent
524 @strong{Note à l'attention des utilisateurs de Windows :} toutes
525 les informations concernant le traitement apparaissent au fur et à
526 mesure dans l'interpréteur de commandes lorsque vous lancez le programme
527 @code{lilypond.exe}, à l'inverse de @w{@code{lilypond-windows.exe}} qui
528 vous renvoie simplement la main.  L'option @option{-dgui} vous permettra
529 alors de rediriger ces informations dans un fichier journal.
530
531 @multitable @columnfractions .33 .16 .51
532 @item @code{help}
533 @tab @code{#f}
534 @tab Affiche cette aide.
535
536 @item @code{include-book-title-preview}
537 @tab @code{#t}
538 @tab Inclut les titres de l'ouvrage dans les images de prévisualisation.
539
540 @item @code{include-eps-fonts}
541 @tab @code{#t}
542 @tab Inclut les fontes dans chaque fichier EPS contenant un système.
543
544 @item @code{include-settings}
545 @tab @code{#f}
546 @tab Inclut un fichier contenant les réglages globaux.  Ce fichier sera
547 inclus avant traitement de la partition.
548
549 @item @code{job-count}
550 @tab @code{#f}
551 @tab Traite plusieurs fichiers en parallèle, selon le nombre de
552 @emph{jobs}.
553
554 @item @code{log-file}
555 @tab @code{#f [fichier]}
556 @tab Fournir @code{TOTO} en second argument redirigera la sortie dans le
557 fichier journal @code{TOTO.log}.
558
559 @item @code{max-markup-depth}
560 @tab @code{1024}
561 @tab Profondeur maximale de l'arborescence de @emph{markups}.  Si un
562 @emph{markup} était plus profond, part du principe qu'on aboutira pas,
563 émet un avertissement et renvoie alors un @emph{markup} vide.
564
565 @item @code{midi-extension}
566 @tab @code{"midi"}
567 @tab Détermine l'extension par défaut des fichiers MIDI, selon la chaîne
568 donnée en argument.
569
570 @item @code{music-strings-to-paths}
571 @tab @code{#f}
572 @tab Convertit les chaînes textuelles en chemins lorsque les glyphes
573 font partie d'une fonte musicale.
574
575 @item @code{old-relative}
576 @tab @code{#f}
577 @tab Affecte au mode @code{\relative} le même comportement pour de la
578 musique simultanée que celui d'une syntaxe d'accords.
579
580 @cindex paper-size, ligne de commande
581 @item @code{paper-size}
582 @tab @code{\"a4\"}
583 @tab Détermine la taille par défaut du papier.  Veillez à ne pas oublier
584 d'encadrer la valeur par des guillemets échappés (@code{\"}).
585 @c Match " in context-sensitive editors
586
587 @item @code{pixmap-format}
588 @tab @code{png16m}
589 @tab Détermine le format de sortie en images pixélisées pour
590 Ghostscript.
591
592 @item @code{point-and-click}
593 @tab @code{#f}
594 @tab Ajoute les liens @qq{point & click} à la sortie @code{PDF}.  Voir
595 @ref{Pointer-cliquer}.
596
597 @cindex format de sortie, définition
598 @cindex preview, ligne de commande
599 @item @code{preview}
600 @tab @code{#f}
601 @tab Génère une prévisualisation en plus de la sortie normale.
602 @end multitable
603
604 @noindent
605 Cette option, disponible dans tous les formats de sortie imprimables --
606 @code{pdf}, @code{png}, @code{ps}, @code{eps} et @code{svg} -- génère
607 un fichier de la forme @code{monFichier.preview.extension} comprenant le
608 titrage et le premier système.  S'il existe plusieurs sections
609 @code{\book}, @code{\bookpart}, ce fichier contiendra les titrage et
610 premier système de chacun des @code{\book}, @code{\bookpart} et
611 @code{\score}, dès lors que la variable @code{print-all-headers} du bloc
612 @code{\paper} est activée.
613
614 Pour l'éviter, utilisez conjointement l'une des options
615 @option{-dprint-pages} ou @option{-dno-print-pages} selon vos besoins.
616
617 @multitable @columnfractions .33 .16 .51
618 @item @code{print-pages}
619 @tab @code{#t}
620 @tab Génère l'intégralité des pages de la partition.  L'option
621 @option{-dno-print-pages} est particulièrement utile lorsqu'utilisée
622 conjointement avec l'option @option{-dpreview}.
623
624 @item @code{profile-property-accesses}
625 @tab @code{#f}
626 @tab Enregistre des statistiques des appels à la fonction
627 @code{get_property()}.
628
629 @item @code{protected-scheme-parsing}
630 @tab @code{#t}
631 @tab Continue en dépit des erreurs que l'analyseur syntaxique
632 détecterait dans du code Scheme inclus.  Lorsque basculé sur @code{#f},
633 stoppe le traitement s'il y a erreur et affiche une trace de la pile.
634
635 @item @code{read-file-list}
636 @tab @code{#f [fichier]}
637 @tab Spécifie un fichier listant les différents fichiers sources à
638 traiter.
639
640 @item @code{relative-includes}
641 @tab @code{#f}
642 @tab Face à une instruction @code{\include}, recherche les fichiers à
643 inclure relativement à l'endroit où se trouve le fichier en cours de
644 traitement plutôt que par rapport au fichier maître.
645
646 @item @code{resolution}
647 @tab @code{101}
648 @tab Détermine, en @code{dpi}, la résolution des pixmaps @code{PNG} à
649 générer selon la valeur donnée.
650
651 @item @code{safe}
652 @tab @code{#f}
653 @tab Ne pas avoir une confiance aveugle dans le code @file{.ly}.
654 @end multitable
655
656 @noindent
657 Lorsque LilyPond est accessible au travers d'un serveur web, il est
658 @strong{impératif} d'utiliser les options @option{--safe} ou
659 @option{--jail}.  L'option @option{--safe} aura pour effet d'empêcher
660 tout code Scheme inclus de mettre en péril votre installation grâce à
661 quelque chose du style
662
663 @quotation
664 @verbatim
665 #(system "rm -rf /")
666 {
667   c4^$(ly:gulp-file "/etc/passwd")
668 }
669 @end verbatim
670 @end quotation
671
672 L'option @code{-dsafe} forcera l'évaluation, au fil de l'eau et par un
673 module sécurisé, des expressions Scheme contenues dans le fichier
674 source.  Ce module sécuritaire, dérivé du module GUILE @file{safe-r5rs},
675 ajoute un certain nombre de fonctions -- listées dans
676 @file{scm/safe-lily.scm} -- à l'API de LilyPond.
677
678 De plus, le mode @emph{safe} ne permet ni l'utilisation de directives
679 @code{\include} ni le recours aux obliques inversées (@emph{backslash})
680 dans les chaînes @TeX{}.  L'import de variables LilyPond dans du code
681 Scheme n'est pas possible en mode sécurisé.
682
683 L'option @code{-dsafe} @strong{ne détecte pas} l'utilisation abusive des
684 ressources.  Il est donc possible que le programme finisse par rester
685 sans réponse si on lui envoie une boucle sans fin.  C'est la raison pour
686 laquelle nous recommandons, lorsque LilyPond tourne sur un serveur
687 accessible au public, d'en limiter aussi bien les ressources processeur
688 que mémoire.
689
690 Notez bien que l'utilisation du mode sécuritaire empêchera aussi la
691 compilation d'un certain nombre de fragments LilyPond.  L'option
692 @code{--jail} est dans ce cas une excellente alternative en terme de
693 sécurité, même si elle requiert plus de temps à mettre en place -- voir
694 @ref{Options basiques de lilypond}.
695
696 @multitable @columnfractions .33 .16 .51
697 @item @code{separate-log-files}
698 @tab @code{#f}
699 @tab Pour les fichiers @code{FICHIER1.ly}, @code{FICHIER2.ly}, etc.
700 enregistre le déroulement dans les journaux @code{FICHIER1.log},
701 @code{FICHIER2.log}@dots{}
702
703 @item @code{show-available-fonts}
704 @tab @code{#f}
705 @tab Liste le nom des fontes disponibles.
706
707 @item @code{strict-infinity-checking}
708 @tab @code{#f}
709 @tab Force le crash en présence des points d'exception de virgule
710 flottante @code{Inf} ou @code{NaN} -- infini ou non-nombre.
711
712 @item @code{strip-output-dir}
713 @tab @code{#t}
714 @tab Supprime, lors du nommage des fichiers résultant, la partie
715 correspondant au répertoire des fichiers sources.
716
717 @item @code{svg-woff}
718 @tab @code{#f}
719 @tab Utilise, avec le moteur SVG, les fontes @code{woff}.
720
721 @item @code{trace-memory-frequency}
722 @tab @code{#f}
723 @tab Enregistre l'utilisation de la cellule Scheme plusieurs fois par
724 seconde, dans les fichiers @code{FICHIER.stacks} et
725 @code{FICHIER.graph}.
726
727 @item @code{trace-scheme-coverage}
728 @tab @code{#f}
729 @tab Enregistre la couverture des fichiers Scheme dans @code{FILE.cov}.
730
731 @item @code{verbose}
732 @tab @code{#f}
733 @tab Passe en mode verbeux, ce qui correspond à un niveau de
734 journalisation @code{DEBUG} (lecture seule).
735
736 @item @code{warning-as-error}
737 @tab @code{#f}
738 @tab Considère tous les messages d'avertissement et @qq{erreur de
739 programmation} comme étant de véritables erreurs.
740 @end multitable
741
742
743 @node Variables d'environnement
744 @unnumberedsubsec Variables d'environnement
745 @translationof Environment variables
746
747 @cindex LANG
748 @cindex LILYPOND_DATADIR
749
750 @command{lilypond} reconnaît les variables d'environnement
751 suivantes :
752
753 @table @code
754 @item LILYPOND_DATADIR
755 Cette variable spécifie le répertoire où seront recherchés par défaut
756 les différentes versions des messages ainsi qu'un certain nombre de
757 fichiers nécessaires au traitement.  Il devrait contenir les
758 sous-répertoires @file{ly/}, @file{ps/}, @file{tex/}, etc.
759
760 @item LANG
761 Cette variable détermine la langue dans laquelle seront émis les
762 messages.
763
764 @item LILYPOND_LOGLEVEL
765 Cette variable détermine le niveau par défaut de verbosité.  En
766 l'absence de niveau explicite -- autrement dit la ligne de commande ne
767 comporte pas de @option{--loglevel} -- c'est cette valeur qui sera
768 utilisée.
769
770 @item LILYPOND_GC_YIELD
771 Cette variable permet d'ajuster l'empreinte mémoire et le rendement de
772 la machine.  Il s'agit en fait d'un pourcentage d'allocation de
773 mémoire : lorsqu'il est élevé, le programme favorisera
774 l'utilisation de la mémoire ; une faible valeur consommera plus de
775 temps processeur.  Par défaut, cette valeur est fixée à @code{70}.
776
777 @end table
778
779
780 @node Exécution de LilyPond en mode protégé
781 @unnumberedsubsec Exécution de LilyPond en mode protégé
782 @translationof LilyPond in chroot jail
783
784 Paramétrer un serveur afin qu'il puisse faire fonctionner LilyPond en
785 mode protégé sur un pseudo-périphérique est une tâche sensible.  Les
786 différentes étapes à suivre sont répertoriées ci-dessous.  Les exemples
787 qu'elle comportent proviennent d'une distribution GNU/Linux Ubuntu et
788 nécessiteront l'utilisation de @code{sudo} autant que de besoin.
789
790 @itemize
791
792 @item Installation des paquetages nécessaires : LilyPond, Ghostscript et
793 ImageMagick.
794
795 @item Création de l'utilisateur @code{lily} :
796
797 @example
798 adduser lily
799 @end example
800
801 @noindent
802 Ceci, par la même occasion, créera un groupe spécifique pour
803 l'utilisateur @code{lily} ainsi que son répertoire personnel
804 @code{/home/lily}.
805
806 @item Création, dans le répertoire personnel de l'utilisateur
807 @code{lily}, d'un espace agissant en tant que système de fichiers :
808
809 @example
810 dd if=/dev/zero of=/home/lily/loopfile bs=1k count= 200000
811 @end example
812
813 @noindent
814 Cette commande a créé un fichier de 200 MB utilisable par le
815 @qq{système protégé}.
816
817 @item Création d'un pseudo-périphérique, génération d'un système de
818 fichiers et chargement de celui-ci, puis création d'un répertoire
819 accessible en écriture pour l'utilisateur @code{lily} :
820
821 @example
822 mkdir /mnt/lilyloop
823 losetup /dev/loop0 /home/lily/loopfile
824 mkfs -t ext3 /dev/loop0 200000
825 mount -t ext3 /dev/loop0 /mnt/lilyloop
826 mkdir /mnt/lilyloop/lilyhome
827 chown lily /mnt/lilyloop/lilyhome
828 @end example
829
830 @item Affectation, au niveau configuration du serveur, de
831 @code{/mnt/lilyloop} en tant que JAIL et @code{/lilyhome} en tant que
832 DIR.
833
834 @item Création d'une arborescence, dans l'espace protégé, et recopie de
835 tous les fichiers nécessaires -- voir le script plus loin.
836
837 Le recours à l'utilitaire @code{sed} permet de créer les commandes de
838 copie de tout ce qui est nécessaire à un exécutable :
839
840 @example
841 for i in "/usr/local/lilypond/usr/bin/lilypond" "/bin/sh" "/usr/bin/;  \
842   do ldd $i | sed 's/.*=> \/\(.*\/\)\([^(]*\).*/mkdir -p \1 \&\&  \
843     cp -L \/\1\2 \1\2/' | sed 's/\t\/\(.*\/\)\(.*\) (.*)$/mkdir -p  \
844       \1 \&\& cp -L \/\1\2 \1\2/' | sed '/.*=>.*/d'; done
845 @end example
846
847 @end itemize
848
849 @subheading Exemple de script fonctionnel en 32-bit sur Ubuntu 8.04
850
851 @example
852 #!/bin/sh
853 ## les réglages par défaut
854
855 username=lily
856 home=/home
857 loopdevice=/dev/loop0
858 jaildir=/mnt/lilyloop
859 # le préfixe (sans slash au début !)
860 lilyprefix=usr/local
861 # le répertoire du système où lilypond est installé
862 lilydir=/$lilyprefix/lilypond/
863
864 userhome=$home/$username
865 loopfile=$userhome/loopfile
866 adduser $username
867 dd if=/dev/zero of=$loopfile bs=1k count=200000
868 mkdir $jaildir
869 losetup $loopdevice $loopfile
870 mkfs -t ext3 $loopdevice 200000
871 mount -t ext3 $loopdevice $jaildir
872 mkdir $jaildir/lilyhome
873 chown $username $jaildir/lilyhome
874 cd $jaildir
875
876 mkdir -p bin usr/bin usr/share usr/lib usr/share/fonts $lilyprefix tmp
877 chmod a+w tmp
878
879 cp -r -L $lilydir $lilyprefix
880 cp -L /bin/sh /bin/rm bin
881 cp -L /usr/bin/convert /usr/bin/gs usr/bin
882 cp -L /usr/share/fonts/truetype usr/share/fonts
883
884 # la formule magique de recopie des bibliothèques
885 for i in "$lilydir/usr/bin/lilypond" "$lilydir/usr/bin/guile" "/bin/sh"  \
886   "/bin/rm" "/usr/bin/gs" "/usr/bin/convert"; do ldd $i | sed 's/.*=>  \
887     \/\(.*\/\)\([^(]*\).*/mkdir -p \1 \&\& cp -L \/\1\2 \1\2/' | sed  \
888       's/\t\/\(.*\/\)\(.*\) (.*)$/mkdir -p \1 \&\& cp -L \/\1\2 \1\2/'  \
889         | sed '/.*=>.*/d'; done | sh -s
890
891 # les fichiers partagés pour ghostscript...
892       cp -L -r /usr/share/ghostscript usr/share
893 # les fichiers partagés pour ImageMagick
894       cp -L -r /usr/lib/ImageMagick* usr/lib
895
896 ### Partant du principe que test.ly est dans /mnt/lilyloop/lilyhome,
897 ### on devrait pouvoir lancer :
898 ### Attention : /$lilyprefix/bin/lilypond est un script qui
899 ### définit LD_LIBRARY_PATH - c'est primordial
900       /$lilyprefix/bin/lilypond -jlily,lily,/mnt/lilyloop,/lilyhome test.ly
901 @end example
902
903
904 @node Messages d'erreur
905 @section Messages d'erreur
906 @translationof Error messages
907
908 @cindex erreur, messages
909
910 Différents messages d'erreur sont susceptibles d'apparaître au cours de
911 la compilation d'un fichier :
912
913 @table @emph
914
915 @item Warning -- Avertissement
916 @cindex warning
917 @cindex avertissement
918 Ce type de message est émis lorsque LilyPond détecte quelque chose de
919 suspect.  Si vous avez demandé quelque chose qui sort de l'ordinaire,
920 vous saurez probablement ce à quoi il est fait référence et ignorerez de
921 tels messages sans remord.  Néanmoins, les messages d'avertissement
922 indiquent la plupart du temps une incohérence dans le fichier source.
923
924 @item Error -- Erreur
925 @cindex error
926 LilyPond a détecté une erreur.  L'étape en cours, qu'il s'agisse de
927 l'analyse, de l'interprétation des données ou bien du formatage, sera
928 menée à son terme, puis LilyPond s'arrêtera.
929
930 @item Fatal error -- Erreur fatale
931 @cindex fatal error
932 LilyPond est confronté à une anomalie bloquante.  Ceci ne se produit que
933 très rarement, et la plupart du temps en raison d'une installation
934 défectueuse des fontes.
935
936 @item Scheme error -- Erreur Scheme
937 @cindex trace, Scheme
938 @cindex call trace
939 @cindex Scheme error
940 Les erreurs qui interviennent lors de l'exécution de code Scheme sont
941 gérées par l'interpréteur Scheme.  L'utilisation du mode verbeux
942 (options @option{-V} ou @option{--verbose}) vous permettra de localiser
943 l'appel de fonction délictueux.
944
945 @item Programming error -- Erreur de programmation
946 @cindex Programming error
947 @cindex Erreur de programmation
948 LilyPond est confronté à une incohérence interne.  Ce type de message
949 est destiné à venir en aide aux développeurs et débogueurs.  En règle
950 générale, vous pouvez tout simplement les ignorer.  Parfois, il y en a
951 tant qu'ils masquent ce qui pourrait vous intéresser@dots{}
952
953 @item Aborted (core dumped) -- Abandon
954 @cindex Aborted (core dumped)
955 Ce type de message indique que LilyPond a planté en raison d'une grave
956 erreur de programmation.  La survenance d'un tel message est considérée
957 comme de la plus haute importance.  Si vous y étiez confronté,
958 transmettez un rapport de bogue.
959 @end table
960
961 @cindex errors, message format
962 Lorsque l'avertissement ou l'erreur est directement lié au fichier
963 source, le message est libellé sous la forme
964
965 @example
966 @var{fichier}:@var{ligne}:@var{colonne}: @var{message}
967 @var{contenu de la ligne litigieuse}
968 @end example
969
970 Un saut de ligne est placé dans la ligne de code, indiquant l'endroit
971 précis du problème, comme ici :
972
973 @example
974 test.ly:2:19: erreur: n'est pas une durée: 5
975   @{ c'4 e'
976            5 g' @}
977 @end example
978
979 Notez que ces coordonnées constituent l'approximation au mieux par
980 LilyPond dans le code ayant déclenché l'avertissement ou l'erreur.  En
981 règle générale, erreurs et avertissements surviennent lorsque LilyPond
982 rencontre quelque chose d'inattendu.  Lorsque la ligne indiquée ne vous
983 semble pas comporter d'élément litigieux, remontez de quelques lignes
984 dans votre code.
985
986 Vous trouverez d'autres informations sur les erreurs au chapitre
987 @ref{Quelques erreurs des plus courantes}.
988
989
990 @node Quelques erreurs des plus courantes
991 @section Quelques erreurs des plus courantes
992 @translationof Common errors
993
994 Les conditions amenant aux erreurs qui suivent sont fréquentes, bien
995 qu'elles ne soient pas évidentes ni facilement localisables.  Nous
996 espérons que ces explications vous aideront à les résoudre plus
997 facilement.
998
999 @menu
1000 * La musique déborde de la page::
1001 * Apparition d'une portée supplémentaire::
1002 * Erreur renvoyant à ../ly/init.ly::
1003 * Message d'erreur Unbound variable %::
1004 * Message d'erreur FT_Get_Glyph_Name::
1005 * staff-affinities devraient aller en ordre décroissant::
1006 @end menu
1007
1008
1009 @node La musique déborde de la page
1010 @unnumberedsubsec La musique déborde de la page
1011 @translationof Music runs off the page
1012
1013 Lorsque la musique s'épanche au delà de la marge droite ou bien semble
1014 anormalement comprimée, la raison en est le plus souvent une note à la
1015 durée erronée ; cela finit par provoquer le débordement de la
1016 dernière note d'une mesure.  Rien ne s'oppose à ce que la dernière note
1017 d'une mesure ne s'arrête avant la barre de mesure ; on considère
1018 simplement qu'elle se prolonge sur la mesure suivante.  Des débordements
1019 à répétition finissent par générer une musique comprimée ou qui sort de
1020 la page, pour la simple et bonne raison que les sauts de ligne
1021 automatiques ne peuvent intervenir qu'à la fin d'une mesure complète,
1022 autrement dit lorsque toutes les notes sont terminées avant la fin de la
1023 mesure.
1024
1025 @warning{Une durée erronée peut empêcher les sauts de ligne, ce qui
1026 conduit à une musique compressée, voire à un débordement de la page.}
1027
1028 Une erreur de durée sera bien plus facilement localisable si vous
1029 positionnez régulièrement des contrôles de barre de mesure -- voir
1030 @ruser{Vérification des limites et numéros de mesure}.
1031
1032 Si vous tenez absolument à enchaîner de tels débordements, vous devrez
1033 insérer des barres de mesure invisibles là où vous souhaitez positionner
1034 un saut de ligne.  Consultez le chapitre @ruser{Barres de mesure} pour
1035 plus de détails.
1036
1037
1038 @node Apparition d'une portée supplémentaire
1039 @unnumberedsubsec Apparition d'une portée supplémentaire
1040 @translationof An extra staff appears
1041
1042 Lorsque les contextes ne sont pas créés explicitement par la commande
1043 @code{\new}, ils le seront si la commande à exécuter n'est pas censée
1044 s'appliquer au contexte en cours.  Pour des partitions simples, le fait
1045 que les contextes soient automatiquement créés rend bien des services,
1046 et c'est d'ailleurs le cas pour la majorité des exemples contenus dans
1047 les manuels de LilyPond.  Cependant, la création implicite d'un contexte
1048 peut aboutir à l'apparition d'une portée @qq{parasite}.  On s'attend par
1049 exemple, en lisant le code qui suit, à ce que toutes les têtes de note
1050 soient en rouge, alors que le résultat nous présente deux portées et que
1051 les notes, placées sur la portée inférieure, restent en noir.
1052
1053 @lilypond[quote,verbatim,relative=2]
1054 \override Staff.NoteHead.color = #red
1055 \new Staff { a }
1056 @end lilypond
1057
1058 Étant donné qu'aucun contexte @code{Staff} n'existe lorsque la
1059 dérogation est introduite, LilyPond le crée implicitement pour lui
1060 appliquer la directive considérée.  Survient alors la commande
1061 @code{\new Staff} qui, à son tour, crée une nouvelle portée pour
1062 contenir les notes qui suivent.  Voici la syntaxe correcte pour obtenir
1063 ces notes en rouge :
1064
1065 @lilypond[quote,verbatim,relative=2]
1066 \new Staff {
1067   \override Staff.NoteHead.color = #red
1068   a
1069 }
1070 @end lilypond
1071
1072 Autre exemple : la présence d'une commande @code{\relative} à
1073 l'intérieur d'une section @code{\repeat} générera obligatoirement une
1074 portée intempestive.  Cela tient au fait que la commande @code{\repeat}
1075 va créer deux blocs @code{\relative} qui, chacun à leur tour, créeront
1076 implicitement un bloc @code{Staff} assorti d'un bloc @code{Voice}.
1077
1078 @lilypond[quote,verbatim]
1079 \repeat unfold 2 {
1080   \relative c' { c4 d e f }
1081 }
1082 @end lilypond
1083
1084 La manière adéquate de procéder consiste à inverser les commandes
1085 @code{\repeat} et @code{\relative}, comme ceci :
1086
1087 @lilypond[quote,verbatim]
1088 \new Voice {
1089   \repeat unfold 2 {
1090     \relative c' { c4 d e f }
1091   }
1092 }
1093 @end lilypond
1094
1095
1096 @node Erreur renvoyant à ../ly/init.ly
1097 @unnumberedsubsec Erreur renvoyant à @code{../ly/init.ly}
1098 @translationof Apparent error in ../ly/init.ly
1099
1100 Certains messages d'erreur relatifs à une erreur de syntaxe dans le
1101 fichier @file{../ly/init.ly} peuvent survenir lorsque le fichier est mal
1102 formaté.  Cela se produit notamment lors d'un défaut de parité de
1103 bornages ou de guillemets.
1104
1105 L'erreur la plus courante est la simple omission d'une accolade
1106 fermante (@code{@}}) à la fin du bloc @code{Score}.  La solution est
1107 évidente en pareil cas : il suffit de vérifier que le bloc
1108 @code{Score} est bien clôturé.  La structure des fichiers LilyPond est
1109 abordée plus en détails au chapitre
1110 @rlearning{Organisation des fichiers LilyPond}.  C'est la raison pour
1111 laquelle nous vous invitons à utiliser un éditeur de texte qui prenne en
1112 charge le contrôle de parité des parenthèses, crochets et accolades afin
1113 de vous éviter de telles erreurs.
1114
1115 Autre erreur courante, l'absence d'espace entre la dernière syllabe et
1116 l'accolade (@code{@}}) clôturant un bloc de paroles.  Lorsqu'il n'y a
1117 pas séparation, l'accolade est considérée comme faisant partie
1118 intégrante de la syllabe.  C'est la raison pour laquelle nous vous
1119 invitons à insérer une espace avant et après @strong{chaque} accolade.
1120 D'autres informations à ce sujets sont mentionnées au chapitre
1121 @ruser{Saisie des paroles}.
1122
1123 Lorsqu'il s'agit d'un guillemet fermant (@code{"}) omis, le message
1124 d'erreur devrait vous indiquer un numéro de ligne avoisinant.  L'erreur
1125 se situe la plupart du temps une ou deux lignes au-dessus de celle
1126 indiquée.
1127 @c Match quote character "
1128
1129 @node Message d'erreur Unbound variable %
1130 @unnumberedsubsec Message d'erreur Unbound variable %
1131 @translationof Error message Unbound variable %
1132
1133 Ce message d'erreur, qu'il apparaisse sur le terminal ou en fin de
1134 fichier journal, est associé à un message du type @qq{GUILE a signalé
1135 une erreur@dots{}}. Il survient à chaque fois qu'un commentaire
1136 @emph{LilyPond} est indûment placé dans une routine @emph{Scheme}.
1137
1138 Un commentaire LilyPond est introduit par le signe pourcent (@code{%})
1139 et ne doit en aucun cas se trouver dans une routine Scheme.  En Scheme,
1140 les commentaires s'introduisent par un point-virgule (@code{;}).
1141
1142
1143 @node Message d'erreur FT_Get_Glyph_Name
1144 @unnumberedsubsec Message d'erreur FT_Get_Glyph_Name
1145 @translationof Error message FT_Get_Glyph_Name
1146
1147 Ce message d'erreur, qu'il apparaisse sur le terminal ou en fin de
1148 fichier journal, survient lorsqu'un fichier source contient des
1149 caractères non ASCII et qu'il n'a pas été enregistré avec un encodage
1150 UTF-8.  Pour plus de détails, reportez-vous au chapitre
1151 @ruser{Caractères spéciaux}.
1152
1153
1154 @node staff-affinities devraient aller en ordre décroissant
1155 @unnumberedsubsec staff-affinities devraient aller en ordre décroissant
1156 @translationof Warning staff affinities should only decrease
1157
1158 Cet avertissement est émis lorsque la partition ne comporte pas de
1159 portée, comme par exemple une feuille de chant avec un contexte
1160 @code{ChordName} et un contexte @code{Lyrics}.  Ce message disparaîtra
1161 dès lors que vous autoriserez l'un de ces contextes à se comporter comme
1162 une portée, à l'aide de l'instruction
1163
1164 @example
1165 \override VerticalAxisGroup.staff-affinity = ##f
1166 @end example
1167
1168 @noindent
1169 que vous insérerez dès sa création.  Pour plus d'information,
1170 reportez-vous à la rubrique
1171 @ruser{Espacement des lignes rattachées à des portées}.