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