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