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