1 @c -*- coding: utf-8; mode: texinfo; documentlanguage: fr -*-
4 Translation of GIT committish: ada15837e81a658a807d004b18877ba67a136fa3
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..
13 @c Translators: Jean-Charles Malahieude
14 @c Translation checkers:
16 @node Exécution de LilyPond
17 @chapter Exécution de @command{lilypond}
18 @translationof Running lilyPond
20 Ce chapitre passe en revue ce qui se passe lorsque vous lancez LilyPond.
23 * Utilisation habituelle::
24 * Utilisation en ligne de commande::
26 * Quelques erreurs des plus courantes::
29 @node Utilisation habituelle
30 @section Utilisation habituelle
31 @translationof Normal usage
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.
40 @node Utilisation en ligne de commande
41 @section Utilisation en ligne de commande
42 @translationof Command-line usage
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
50 Par @qq{ligne de commande}, nous entendons l'interface de commande du
51 système. Les utilisateurs de Windows seront certainement plus familiers
52 des termes @qq{fenêtre DOS} ou @qq{invite de commande}. Quant aux
53 utilisateurs de MacOS@tie{}X, ils connaissent assurément les termes
54 @qq{console} et @qq{terminal}. Les paramétrages spécifiques au système
55 MacOS font l'objet d'un @rwebnamed{MacOS X,chapitre particulier}.
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.
64 * Lancement de lilypond::
65 * Options en ligne de commande pour lilypond::
66 * Variables d'environnement::
67 * Exécution de LilyPond en mode protégé::
70 @node Lancement de lilypond
71 @unnumberedsubsec Lancement de @command{lilypond}
72 @translationof Invoking lilypond
74 L'exécutable @command{lilypond} en ligne de commande se lance
78 lilypond [@var{option}]@dots{} @var{fichier}@dots{}
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
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@tie{}; 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.}
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
100 #(define output-suffix "violon")
102 #(define output-suffix "cello")
107 fournira grâce à LilyPond @file{@var{racine}-violon.pdf} et
108 @file{@var{racine}-cello-1.pdf}.
111 @unnumberedsubsubsec Commandes standard de l'interpréteur
112 @translationof Standard shell commands
114 Si votre interpréteur -- terminal, console, etc. -- prend en charge les
115 redirections, les commandes qui suivent vous permettront de
116 judicieusement rediriger les affichages de la console dans un
122 @code{lilypond fichier.ly 1>stdout.log} pour le verbiage normal
125 @code{lilypond fichier.ly 2>stderr.log} pour les messages d'erreur
128 @code{lilypond fichier.ly &>tous.log} pour garder une trace de tout ce
133 Consultez avant tout la documentation de votre interpréteur habituel
134 pour vérifier qu'il prend en charge ces options dans cette syntaxe.
135 Notez bien qu'il s'agit ici de commandes internes à l'interpréteur et
136 qui n'ont rien à voir avec LilyPond.
139 @node Options en ligne de commande pour lilypond
140 @unnumberedsubsec Options en ligne de commande pour @command{lilypond}
141 @translationof Command line options for lilypond
143 @cindex lancement de @command{lilypond}
144 @cindex ligne de commande, options pour @command{lilypond}
145 @cindex options, ligne de commande
149 Voici les différentes options disponibles à la ligne de commande@tie{}:
153 @item -e,--evaluate=@var{expr}
154 Évalue l'expression Scheme @var{expr} avant d'analyser tout fichier
155 @file{.ly}. Lorsque vous spécifiez l'option @code{-e} à plusieurs
156 reprises, l'évaluation sera faite en séquence.
158 Dans la mesure où l'expression est évaluée par le module
159 @code{guile-user}, vous devrez, dès lors que @var{expr} utilise des
160 définitions, spécifier
163 lilypond -e '(define-public a 42)'
167 en ligne de commande, et ajouter la ligne
170 #(use-modules (guile-user))
174 en tête de votre fichier @file{.ly}.
177 @item -f,--format=@var{format}
178 Détermine le format à produire. Il peut s'agir de @code{ps}, @code{pdf}
181 Exemple : @code{lilypond -fpng @var{monfichier}.ly}
184 @item -d,--define-default=@var{var}=@var{val}
185 Affecte la valeur Scheme @var{val} à l'option interne @var{var} du
186 programme. En l'absence de @var{val}, le programme utilisera @var{#t}.
187 Préfixer @var{var} d'un @code{no-} vous permet de désactiver une option.
190 @cindex point and click, ligne de commande
199 -dpoint-and-click='#f'
203 Voici quelques options des plus intéressantes.
205 @cindex help, ligne de commande
209 Lancer @code{lilypond -dhelp} affichera la liste de toutes les options
210 @code{-d} disponibles.
213 @cindex paper-size, ligne de commande
216 Détermine la taille par défaut du papier, par exemple
218 -dpaper-size=\"letter\"
222 Veillez à ne pas oublier d'encadrer la valeur par des guillemets
223 échappés ( @code{\"} ).
224 @c Match " in previous line to help context-sensitive editors
227 @cindex safe, ligne de commande
230 Ne pas avoir une confiance aveugle dans le code @file{.ly}.
232 Lorsque LilyPond est accessible au travers d'un serveur web, il est
233 @strong{impératif} d'utiliser les options @code{--safe} ou
234 @code{--jail}. L'option @code{--safe} aura pour effet d'empêcher tout
235 code Scheme inclus de mettre en péril votre installation grâce à quelque
242 c4^#(ly:export (ly:gulp-file "/etc/passwd"))
247 L'option @code{-dsafe} forcera l'évaluation, au fil de l'eau et par un
248 module sécurisé, des expressions Scheme contenues dans le fichier
249 source. Ce module sécuritaire, dérivé du module GUILE @file{safe-r5rs},
250 ajoute un certain nombre de fonctions -- listées dans
251 @file{scm/safe-lily.scm} -- à l'API de LilyPond.
253 De plus, le mode @emph{safe} ne permet ni l'utilisation de directives
254 @code{\include} ni le recours aux obliques inversées (@emph{backslash})
255 dans les chaînes @TeX{}.
257 L'import de variables LilyPond dans du code Scheme n'est pas possible
260 L'option @code{-dsafe} @strong{ne détecte pas} l'utilisation abusive des
261 ressources. Il est donc possible que le programme finisse par rester
262 sans réponse si on lui envoie une boucle sans fin. C'est la raison pour
263 laquelle nous recommandons, lorsque LilyPond tourne sur un serveur
264 accessible au public, d'en limiter aussi bien les ressources processeur
267 Notez bien que l'utilisation du mode sécuritaire empêchera aussi la
268 compilation d'un certain nombre de fragments LilyPond. L'option
269 @option{--jail} est dans ce cas une excellente alternative en terme de
270 sécurité, même si elle requiert plus de temps à mettre en place.
273 @cindex format de sortie, définition
276 Détermine le format de sortie à utiliser par le moteur de traitement.
277 Les types de @code{format} reconnus sont
280 @cindex PostScript output
283 Les fichiers PostScript incluent les polices TTF, Type1 et OTF, et
284 aucune substitution ne sera opérée pour ces fontes. Si vous utilisez
285 des caractères orientaux, le fichier aura vite fait d'atteindre une
290 @cindex Postscript encapsulé
291 @cindex EPS (Encapsulated PostScript)
292 pour du PostScript encapsulé.
294 Chaque page (système) fera l'objet d'un fichier @file{EPS} particulier,
295 sans fontes, auquel sera associé un fichier @file{EPS} qui, lui,
296 contiendra toutes les pages (systèmes) et les fontes.
298 Notez qu'il s'agit du mode que @command{lilypond-book} utilise par défaut.
301 @cindex SVG (Scalable Vector Graphics)
302 pour du SVG (@emph{Scalable Vector Graphics}).
304 Cette option permet de créer un fichier SVG par page, sans incorporation
305 des fontes. Nous vous recommandons d'installer les fontes Century
306 Schoolbook comprises dans le paquetage LilyPond afin d'obtenir le
307 meilleur rendu possible. Sous UNIX, il suffit de les recopier, à partir
308 du répertoire @file{/usr/share/lilypond/VERSION/fonts/otf/}, dans
309 @file{~/.fonts/}. Les fichiers SVG alors générés devraient être
310 lisibles par votre éditeur SVG habituel.
314 pour une recopie brute des commandes Scheme internes de formatage.
317 permet de ne pas générer de partition imprimable. Cette option est
318 équivalente à @code{-dno-print-pages}.
322 Exemple : @code{lilypond -dbackend=svg @var{monfichier}.ly}
326 @cindex preview, ligne de commande
327 Génère un fichier comprenant le titrage et le premier système. S'il
328 existe plusieurs sections @code{\bookpart}, ce fichier contiendra les
329 titrage et premier système de chacun des @code{\bookpart}. Cette
330 option fonctionne pour les moteurs de traitement @code{ps}, @code{eps}
335 Travaille silencieusement, et redirige tout le verbiage dans un fichier
338 Note à l'attention des utilisateurs de Windows@tie{}: toutes les
339 informations concernant le traitement apparaissent au fur et à mesure
340 dans l'interpréteur de commandes lorsque vous lancez le programme
341 @code{lilypond.exe}, à l'inverse de @w{@code{lilypond-windows.exe}} qui
342 vous renvoie simplement la main. L'option @option{-dgui} vous permettra
343 alors de rediriger ces informations dans un fichier journal.
347 Génère l'intégralité des pages de la partition. L'option
348 @code{-dno-print-pages} est particulièrement utile lorsqu'utilisée
349 conjointement avec l'option @code{-dpreview}.
356 Affiche un résumé des commandes.
359 @item -H,--header=@var{CHAMP}
360 Recopie le champ d'entête dans le fichier @file{RACINE.@var{CHAMP}}.
363 @item --include, -I=@var{répertoire}
364 @cindex recherche de fichier
367 Ajoute @var{répertoire} au chemin de recherche pour les inclusions.
369 Vous pouvez mentionner plusieurs fois l'option @code{-I}, auquel cas le
370 la recherche commencera dans le premier répertoire inclus et, si le
371 fichier en question ne s'y trouve pas, les répertoires suivants seront
372 examinés l'un après l'autre.
375 @item -i,--init=@var{fichier}
376 Définit @var{fichier} (par défaut @file{init.ly}) en tant que fichier
380 @item -o,--output=@var{FICHIER} ou @var{RÉP}
381 @cindex répertoire de destination
382 @cindex fichier de destination
384 Détermine le nom par défaut du fichier résultant à @var{FICHIER}@tie{};
385 lorsque l'argument @var{RÉP} correspond à un répertoire déjà existant,
386 c'est là que les fichiers résultants seront déposés. Le suffixe adéquat
387 sera ajouté (p.ex. @file{.pdf} pour du pdf) dans tous les cas.
390 @cindex PostScript output
393 Génère du PostScript.
396 @cindex Portable Network Graphics (PNG) output
399 Génère une image par page, au format PNG@tie{}; ceci sous-entend
400 l'utilisation de @code{--ps}. La résolution de l'image, en DPI, peut se
401 régler en ajoutant par exemple
407 @cindex Portable Document Format (PDF) output
410 Génère du PDF. Ceci sous-entend l'utilisation de @code{--ps}.
413 @item -j,--jail=@var{user},@var{group},@var{jail},@var{dir}
414 Lance @command{lilypond} dans un environnement protégé.
416 L'option @code{--jail} est une alternative qui offre plus de flexibilité
417 que l'option @code{--safe} lorsque LilyPond est installé sur un serveur
418 web ou traite des fichiers externes.
420 L'option @code{--jail} va détourner la racine de @command{lilypond} sur
421 @code{jail} juste avant d'effectuer la compilation à proprement parler.
422 L'utilisateur et le groupe sont modifiés en conséquence, et le
423 répertoire en cours devient @code{dir}. Ces réglages assurent -- du
424 moins en théorie -- l'impossibilité de s'échapper de la cellule. Notez
425 cependant que, pour que l'option @code{--jail} soit fonctionnelle,
426 @code{lilypond} doit être lancé en tant qu'administrateur -- ce qui se
427 réalise aisément à l'aide de la commande @command{sudo}.
429 La création d'un environnement sécurisé requiert quelques précautions
430 dans la mesure où LilyPond doit disposer de tout ce dont il a besoin
431 pour compiler le fichier source @strong{à l'intérieur de la cellule}.
432 L'ermitage, avant d'être viable, requiert donc les étapes
436 @item Création d'un système de fichiers indépendant
437 L'intérêt d'un système de fichiers dédié à LilyPond réside dans le fait
438 qu'on peut le brider à l'aide des options @code{noexec}, @code{nodev} et
439 @code{nosuid}. Il sera de fait impossible de lancer des exécutables ou
440 d'écrire sur un périphérique à partir de LilyPond. Si vous n'avez pas
441 l'intention de créer un tel système sur une partition séparée, vous
442 pouvez avoir recours à un pseudo-périphérique (@emph{loop device}) monté
443 à partir d'un simple fichier de taille raisonnable. D'autre part, le
444 recours à un système de fichiers indépendant permet de limiter l'espace
447 @item Création d'un utilisateur spécifique
448 L'utilisation de LilyPond au sein de la cellule devrait être réservé à
449 un utilisateur aux droits restreints. Il faudra donc créer un
450 utilisateur et un groupe spécifiques -- disons @code{lily}/@code{lily}
451 -- qui n'aura accès en écriture qu'à un unique répertoire déterminé par
452 la valeur de @var{dir}.
454 @item Agencement des lieux
455 LilyPond a besoin d'un certain nombre de fichiers pour pouvoir tourner
456 correctement. Ces fichiers devront donc tous se retrouver dans
457 l'environnement protégé, distribués selon la même arborescence que dans
458 le système d'origine. Ainsi l'intégralité de l'installation de LilyPond
459 (en principe @file{/usr/share/lilypond}) doit y être dupliquée.
461 En cas de problème, lancer LilyPond en utilisant @code{strace} devrait
462 vous permettre de déterminer quels fichiers manquent à l'appel.
464 @item Lancement de LilyPond
465 Dans un environnement protégé monté avec l'option @code{noexec}, il est
466 impossible de lancer un quelconque programme extérieur. LilyPond ne
467 saurait donc avoir recours à un moteur de traitement qui le mettrait
468 dans cette situation. Comme nous l'avons vu plus haut, LilyPond sera
469 lancé avec les privilèges de l'administrateur -- privilèges qu'il perdra
470 aussitôt --, ce qui peut nécessiter le recours à la commande
471 @code{sudo}. Il est par ailleurs judicieux de limiter le temps
472 processeur aloué à LilyPond -- grâce à @command{ulimit@tie{}-t} par
473 exemple -- ainsi que, si votre système le permet, la taille de la
479 Affiche le numéro de version.
483 Active le mode verbeux@tie{}: affichage de l'intégralité du chemin
484 d'accès de chaque fichier, et information des temps de traitement.
488 Affiche les informations de garantie appliquables à GNU LilyPond -- il
489 est livré @strong{SANS GARANTIE}@tie{}!
493 @node Variables d'environnement
494 @unnumberedsubsec Variables d'environnement
495 @translationof Environment variables
498 @cindex LILYPOND_DATADIR
500 @command{lilypond} reconnaît les variables d'environnement
503 @item LILYPOND_DATADIR
504 Cette variable spécifie le répertoire où seront recherchés par défaut
505 les différentes versions des messages ainsi qu'un certain nombre de
506 fichiers nécessaires au traitement. Il devrait contenir les
507 sous-répertoires @file{ly/}, @file{ps/}, @file{tex/}, etc.
510 Cette variable détermine la langue dans laquelle seront émis les
513 @item LILYPOND_GC_YIELD
514 Cette variable permet d'ajuster l'empreinte mémoire et le rendement de
515 la machine. Il s'agit en fait d'un pourcentage d'allocation de
516 mémoire@tie{}: lorsqu'il est élevé, le programme favorisera
517 l'utilisation de la mémoire@tie{}; une faible valeur consommera plus de
518 temps processeur. Par défaut, cette valeur est fixée à@tie{}@code{70}.
523 @node Exécution de LilyPond en mode protégé
524 @unnumberedsubsec Exécution de LilyPond en mode protégé
525 @translationof LilyPond in chroot jail
527 Paramétrer un serveur afin qu'il puisse faire fonctionner LilyPond en
528 mode protégé sur un pseudo-périphérique est une tâche sensible. Les
529 différentes étapes à suivre sont répertoriées ci-dessous. Les exemples
530 qu'elle comportent proviennent d'une distribution Linux Ubuntu et
531 nécessiteront l'utilisation de @code{sudo} autant que de besoin.
535 @item Installation des paquetages nécessaires@tie{}: LilyPond, GhostScript et
538 @item Création de l'utilisateur @code{lily}:
545 Ceci, par la même occasion, créera un groupe spécifique pour
546 l'utilisateur @code{lily} ainsi que son répertoire personnel
549 @item Création, dans le répertoire personnel de l'utilisateur
550 @code{lily}, d'un espace agissant en tant que système de fichiers@tie{}:
553 dd if=/dev/zero of=/home/lily/loopfile bs=1k count= 200000
557 Cette commande a créé un fichier de 200@tie{}MB utilisable par le
558 @qq{système protégé}.
560 @item Création d'un pseudo-périphérique, génération d'un système de
561 fichiers et chargement de celui-ci, puis création d'un répertoire
562 accessible en écriture pour l'utilisateur @code{lily}@tie{}:
566 losetup /dev/loop0 /home/lily/loopfile
567 mkfs -t ext3 /dev/loop0 200000
568 mount -t ext3 /dev/loop0 /mnt/lilyloop
569 mkdir /mnt/lilyloop/lilyhome
570 chown lily /mnt/lilyloop/lilyhome
573 @item Affectation, au niveau configuration du serveur, de
574 @code{/mnt/lilyloop} en tant que JAIL et @code{/lilyhome} en tant que
577 @item Création d'une arborescence, dans l'espace protégé, et recopie de
578 tous les fichiers nécessaires -- voir le script plus loin.
580 Le recours à l'utilitaire @code{sed} permet de créer les commandes de
581 copie de tout ce qui est nécessaire à un exécutable@tie{}:
584 for i in "/usr/local/lilypond/usr/bin/lilypond" "/bin/sh" "/usr/bin/; \
585 do ldd $i | sed 's/.*=> \/\(.*\/\)\([^(]*\).*/mkdir -p \1 \&\& \
586 cp -L \/\1\2 \1\2/' | sed 's/\t\/\(.*\/\)\(.*\) (.*)$/mkdir -p \
587 \1 \&\& cp -L \/\1\2 \1\2/' | sed '/.*=>.*/d'; done
592 @subheading Exemple de script fonctionnel en 32-bit sur Ubuntu 8.04
596 ## les réglages par défaut
600 loopdevice=/dev/loop0
601 jaildir=/mnt/lilyloop
602 # le préfixe (sans slash au début !)
604 # le répertoire du système où lilypond est installé
605 lilydir=/$lilyprefix/lilypond/
607 userhome=$home/$username
608 loopfile=$userhome/loopfile
610 dd if=/dev/zero of=$loopfile bs=1k count=200000
612 losetup $loopdevice $loopfile
613 mkfs -t ext3 $loopdevice 200000
614 mount -t ext3 $loopdevice $jaildir
615 mkdir $jaildir/lilyhome
616 chown $username $jaildir/lilyhome
619 mkdir -p bin usr/bin usr/share usr/lib usr/share/fonts $lilyprefix tmp
622 cp -r -L $lilydir $lilyprefix
623 cp -L /bin/sh /bin/rm bin
624 cp -L /usr/bin/convert /usr/bin/gs usr/bin
625 cp -L /usr/share/fonts/truetype usr/share/fonts
627 # la formule magique de recopie des biblothèques
628 for i in "$lilydir/usr/bin/lilypond" "$lilydir/usr/bin/guile" "/bin/sh" \
629 "/bin/rm" "/usr/bin/gs" "/usr/bin/convert"; do ldd $i | sed 's/.*=> \
630 \/\(.*\/\)\([^(]*\).*/mkdir -p \1 \&\& cp -L \/\1\2 \1\2/' | sed \
631 's/\t\/\(.*\/\)\(.*\) (.*)$/mkdir -p \1 \&\& cp -L \/\1\2 \1\2/' \
632 | sed '/.*=>.*/d'; done | sh -s
634 # les fichiers partagés pour ghostscript...
635 cp -L -r /usr/share/ghostscript usr/share
636 # les fichiers partagés pour ImageMagick
637 cp -L -r /usr/lib/ImageMagick* usr/lib
639 ### Partant du principe que test.ly est dans /mnt/lilyloop/lilyhome,
640 ### on devrait pouvoir lancer :
641 ### Attention : /$lilyprefix/bin/lilypond est un script qui
642 ### définit LD_LIBRARY_PATH - c'est primordial
643 /$lilyprefix/bin/lilypond -jlily,lily,/mnt/lilyloop,/lilyhome test.ly
647 @node Messages d'erreur
648 @section Messages d'erreur
649 @translationof Error messages
651 @cindex erreur, messages
653 Différents messages d'erreur sont susceptibles d'apparaître au cours de
654 la compilation d'un fichier@tie{}:
658 @item Warning -- Avertissement
660 @cindex avertissement
661 Ce type de message est émis lorsque LilyPond détecte quelque chose de
662 suspect. Si vous avez demandé quelque chose qui sort de l'ordinaire,
663 vous saurez probablement ce à quoi il est fait référence et ignorerez de
664 tels messages sans remord. Néanmoins, les messages d'avertissement
665 indiquent la plupart du temps une incohérence dans le fichier source.
667 @item Error -- Erreur
669 LilyPond a détecté une erreur. L'étape en cours, qu'il s'agisse de
670 l'analyse, de l'interprétation des données ou bien du formatage, sera
671 menée à son terme, puis LilyPond s'arrêtera.
673 @item Fatal error -- Erreur fatale
675 LilyPond est confronté à une anomalie bloquante. Ceci ne se produit que
676 très rarement, et la plupart du temps en raison d'une installation
677 défectueuse des fontes.
679 @item Scheme error -- Erreur Scheme
680 @cindex trace, Scheme
683 Les erreurs qui interviennent lors de l'exécution de code Scheme sont
684 gérées par l'interpréteur Scheme. L'utilisation du mode verbeux
685 (options @code{-V} ou @code{--verbose}) vous permettra de localiser
686 l'appel de fonction délictueux.
688 @item Programming error -- Erreur de programmation
689 @cindex Programming error
690 @cindex Erreur de programmation
691 LilyPond est confronté à une incohérence interne. Ce type de message
692 est destiné à venir en aide aux développeurs et débogueurs. En règle
693 générale, vous pouvez tout simplement les ignorer. Parfois, il y en a
694 tant qu'ils masquent ce qui pourrait vous intéresser@dots{}
696 @item Aborted (core dumped) -- Abandon
697 @cindex Aborted (core dumped)
698 Ce type de message indique que LilyPond a planté en raison d'une grave
699 erreur de programmation. La survenance d'un tel message est considérée
700 comme de la plus haute importance. Si vous y étiez confronté,
701 transmettez un rapport de bogue.
704 @cindex errors, message format
705 Lorsque l'avertissement ou l'erreur est directement lié au fichier
706 source, le message est libellé sous la forme
709 @var{fichier}:@var{ligne}:@var{colonne}: @var{message}
710 @var{contenu de la ligne litigieuse}
713 Un saut de ligne est placé dans la ligne de code, indiquant l'endroit
714 précis du problème, comme ici@tie{}:
717 test.ly:2:19: erreur: n'est pas une durée: 5
722 Notez que ces coordonnées constituent l'approximation au mieux par
723 LilyPond dans le code ayant déclenché l'avertissement ou l'erreur. En
724 règle générale, erreurs et avertissement surviennent lorsque LilyPond
725 rencontre quelque chose d'inattendu. Lorsque la ligne indiquée ne vous
726 semble pas comporter d'élément litigieux, remontez de quelques lignes
729 Vous trouverez d'autres informations sur les erreurs au chapitre
730 @ref{Quelques erreurs des plus courantes}.
733 @node Quelques erreurs des plus courantes
734 @section Quelques erreurs des plus courantes
735 @translationof Common errors
737 Les conditions amenant aux erreurs qui suivent sont fréquentes, bien
738 qu'elles ne soient pas évidentes ni facilement localisables. Nous
739 espérons que ces explications vous aideront à les résoudre plus
744 * La musique déborde de la page::
745 * Apparition d'une portée supplémentaire::
746 * Erreur renvoyant à ../ly/init.ly::
747 * Message d'erreur Unbound variable %::
748 * Message d'erreur FT_Get_Glyph_Name::
749 * staff-affinities devraient aller en ordre décroissant::
752 @node La musique déborde de la page
753 @unnumberedsubsec La musique déborde de la page
754 @translationof Music runs off the page
756 Lorsque la musique s'épanche au delà de la marge droite ou bien semble
757 anormalement comprimée, la raison en est le plus souvent une note à la
758 durée erronée@tie{}; cela finit par provoquer le débordement de la
759 dernière note d'une mesure. Rien ne s'oppose à ce que la dernière note
760 d'une mesure ne s'arrête avant la barre de mesure@tie{}; on considère
761 simplement qu'elle se prolonge sur la mesure suivante. Des débordements
762 à répétition finissent par générer une musique comprimée ou qui sort de
763 la page, pour la simple et bonne raison que les sauts de ligne
764 automatiques ne peuvent intervenir qu'à la fin d'une mesure complète,
765 autrement dit lorsque toutes les notes sont terminées avant la fin de la
768 @warning{Une durée erronée peut empêcher les sauts de ligne, ce qui
769 conduit à une musique compressée, voire à un débordement de la page.}
771 Une erreur de durée sera bien plus facilement localisable si vous
772 positionnez régulièrement des contrôles de barre de mesure -- voir
773 @ruser{Vérification des limites et numéros de mesure}.
775 Si vous tenez absolument à enchainer de tels débordements, vous devrez
776 insérer des barres de mesure invisibles là où vous souhaitez positionner
777 un saut de ligne. Consultez le chapitre @ruser{Barres de mesure} pour
781 @node Apparition d'une portée supplémentaire
782 @unnumberedsubsec Apparition d'une portée supplémentaire
783 @translationof An extra staff appears
785 Lorsque les contextes ne sont pas créés explicitement par la commande
786 @code{\new}, ils le seront si la commande à exécuter n'est pas censée
787 s'appliquer au contexte en cours. Pour des partitions simples, le fait
788 que les contextes soient automatiquement créés rend bien des services,
789 et c'est d'ailleurs le cas pour la majorité des exemples contenus dans
790 les manuels de LilyPond. Cependant, la création implicite d'un contexte
791 peut aboutir à l'apparition d'une portée @qq{parasite}. On s'attend par
792 exemple, en lisant le code qui suit, à ce que toutes les têtes de notes
793 soient en rouge, alors que le résultat nous présente deux portées et que
794 les notes, placées sur la portée inférieure, restent en noir.
796 @lilypond[quote,verbatim,relative=2]
797 \override Staff.NoteHead #'color = #red
801 Étant donné qu'aucun contexte @code{Staff} n'existe lorsque la
802 dérogation est introduite, LilyPond le crée implicitement pour lui
803 appliquer la directive considérée. Survient alors la commande
804 @w{@code{\new Staff}} qui, à son tour, crée une nouvelle portée pour
805 contenir les notes qui suivent. Voici la syntaxe correcte pour obtenir
806 ces notes en rouge@tie{}:
808 @lilypond[quote,verbatim,relative=2]
810 \override Staff.NoteHead #'color = #red
815 Autre exemple : la présence d'une commande @code{\relative} à
816 l'intérieur d'une section @code{\repeat} génèrera obligatoirement une
817 portée intempestive. Cela tient au fait que la commande @code{\repeat}
818 va créer deux blocs @code{\relative} qui, chacun à leur tour, créeront
819 implicitement un bloc @code{Staff} assorti d'un bloc @code{Voice}.
821 @lilypond[quote,verbatim]
822 \repeat unfold 2 \relative { c d e f }
825 La manière adéquate de procéder consiste à inverser les commandes
826 @code{\repeat} et @code{\relative}, comme ceci@tie{}:
828 @lilypond[quote,verbatim]
830 \repeat unfold 2 { c d e f }
835 @node Erreur renvoyant à ../ly/init.ly
836 @unnumberedsubsec Erreur renvoyant à @code{../ly/init.ly}
837 @translationof Apparent error in ../ly/init.ly
839 Certains messages d'erreur relatifs à une erreur de syntaxe dans le
840 fichier @file{../ly/init.ly} peuvent survenir lorsque le fichier est mal
841 formaté. Cela se produit notamment lors d'un défaut de parité de
842 bornages ou de guillemets.
844 L'erreur la plus courante est la simple omission d'une accolade
845 fermante (@code{@}} à la fin du bloc @code{Score}. La solution est
846 évidente en pareil cas@tie{}: il suffit de vérifier que le bloc
847 @code{Score} est bien clôturé. La structure des fichiers LilyPond est
848 abordée plus en détails au chapitre
849 @rlearning{Organisation des fichiers LilyPond}. C'est la raison pour
850 laquelle nous vous invitons à utiliser un éditeur de texte qui prenne en
851 charge le contrôle de parité des parenthèses, crochets et accolades afin
852 de vous éviter de telles erreurs.
854 Lorsqu'il s'agit d'un guillemet fermant (@code{"}) omis, le message
855 d'erreur devrait vous indiquer un numéro de ligne avoisinant. L'erreur
856 se situe la plupart du temps une ou deux lignes au-dessus de celle
860 @node Message d'erreur Unbound variable %
861 @unnumberedsubsec Message d'erreur « Unbound variable % »
862 @translationof Error message Unbound variable %
864 Ce message d'erreur, qu'il apparaisse sur le terminal ou en fin de
865 fichier journal, est associé à un message du type @qq{GUILE a signalé
866 une erreur @dots{}}. Il survient à chaque fois qu'un commentaire
867 @emph{LilyPond} est indûment placé dans une routine @emph{Scheme}.
869 Un commentaire LilyPond est introduit par le signe pourcent (@code{%})
870 et ne doit en aucun cas se trouver dans une routine Scheme. En Scheme,
871 les commentaires s'introduisent par un point-virgule (@code{;}).
874 @node Message d'erreur FT_Get_Glyph_Name
875 @unnumberedsubsec Message d'erreur « FT_Get_Glyph_Name »
876 @translationof Error message FT_Get_Glyph_Name
878 Ce message d'erreur, qu'il apparaisse sur le terminal ou en fin de
879 fichier journal, survient lorsqu'un fichier source contient des
880 caractères non ASCII et qu'il n'a pas été enregistré avec un encodage
881 UTF-8. Pour plus de détails, reportez-vous au chapitre
882 @ruser{Codage du texte}.
885 @node staff-affinities devraient aller en ordre décroissant
886 @unnumberedsubsec staff-affinities devraient aller en ordre décroissant
887 @translationof Warning staff affinities should only decrease
889 Cet avertissement est émis lorsque la partition ne comporte pas de
890 portée, comme par exemple une feuille de chant avec un contexte
891 @code{ChordName} et un contexte @code{Lyrics}. Ce message disparaîtra
892 dès lors que autoriserez l'un de ces contextes à se comporter comme une
893 portée, à l'aide de l'instruction
896 \override VerticalAxisGroup #'staff-affinity = ##f
900 que vous insérerez dès sa création. Pouur plus d'information,
901 reportez-vous à la rubrique
902 @ruser{Espacement des lignes rattachées à des portées}.