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