]> git.donarmstrong.com Git - lilypond.git/blob - Documentation/fr/usage/running.itely
02f26d1e0b9dbea45b54d988f4f9535686355e14
[lilypond.git] / Documentation / fr / usage / running.itely
1 @c -*- coding: utf-8; mode: texinfo; documentlanguage: fr -*-
2
3 @ignore
4     Translation of GIT committish: ede6552ee0a9954a6ced5922cfc0cfa2c40733af
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.13.36"
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 @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}.
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
63 @menu
64 * Lancement de lilypond::
65 * Options en ligne de commande::
66 * Variables d'environnement::
67 * Exécution de LilyPond en mode protégé::
68 @end menu
69
70 @node Lancement de lilypond
71 @unnumberedsubsec Lancement de @command{lilypond}
72 @translationof Invoking lilypond
73
74 L'exécutable @command{lilypond} en ligne de commande se lance
75 ainsi@tie{}:
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@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.}
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 Commandes standard de l'interpréteur
112
113 Si votre interpréteur -- terminal, console, etc. -- prend en charge les
114 redirections, les commandes qui suivent vous permettront de
115 judicieusement rediriger les affichages de la console dans un
116 fichier@tie{}:
117
118 @itemize
119
120 @item
121 @code{lilypond fichier.ly 1>stdout.log} pour le verbiage normal
122
123 @item
124 @code{lilypond fichier.ly 2>stderr.log} pour les messages d'erreur
125
126 @item
127 @code{lilypond fichier.ly &>tous.log} pour garder une trace de tout ce
128 qui s'est passé
129
130 @end itemize
131
132 Consultez avant tout la documentation de votre interpréteur habituel
133 pour vérifier qu'il prend en charge ces options dans cette syntaxe.
134 Notez bien qu'il s'agit ici de commandes internes à l'interpréteur et
135 qui n'ont rien à voir avec LilyPond.
136
137
138 @node Options en ligne de commande
139 @unnumberedsubsec Options en ligne de commande pour @command{lilypond}
140 @translationof Command line options
141
142 @cindex lancement de @command{lilypond}
143 @cindex ligne de commande, options pour @command{lilypond}
144 @cindex options, ligne de commande
145 @cindex switches
146 @cindex commutateurs
147
148 Voici les différentes options disponibles à la ligne de commande@tie{}:
149
150 @table @code
151
152 @item -e,--evaluate=@var{expr}
153 Évalue l'expression Scheme @var{expr} avant d'analyser tout fichier
154 @file{@/.ly}.  Lorsque vous spécifiez l'option @code{-e} à plusieurs
155 reprises, l'évaluation sera faite en séquence.
156
157 Dans la mesure où l'expression est évaluée par le module
158 @code{guile-user}, vous devrez, dès lors que @var{expr} utilise des
159 définitions, spécifier
160
161 @example
162 lilypond -e '(define-public a 42)'
163 @end example
164
165 @noindent
166 en ligne de commande, et ajouter la ligne
167
168 @example
169 #(use-modules (guile-user))
170 @end example
171
172 @noindent
173 en tête de votre fichier @file{@/.ly}.
174
175
176 @item -f,--format=@var{format}
177 Détermine le format à produire.  Il peut s'agir de @code{ps}, @code{pdf}
178 ou @code{png}.
179
180 Exemple : @code{lilypond -fpng @var{monfichier}.ly}
181
182
183 @item -d,--define-default=@var{var}=@var{val}
184 Affecte la valeur Scheme @var{val} à l'option interne @var{var} du
185 programme.  En l'absence de @var{val}, le programme utilisera @var{#t}.
186 Préfixer @var{var} d'un @code{no-} vous permet de désactiver une option.
187 Ainsi,
188
189 @cindex point and click, ligne de commande
190
191 @example
192 -dno-point-and-click
193 @end example
194
195 @noindent
196 revient au même que
197 @example
198 -dpoint-and-click='#f'
199 @end example
200
201
202 Voici quelques options des plus intéressantes.
203
204 @cindex help, ligne de commande
205
206 @table @samp
207 @item help
208 Lancer @code{lilypond -dhelp} affichera la liste de toutes les options
209 @code{-d} disponibles.
210
211
212 @cindex paper-size, ligne de commande
213
214 @item paper-size
215 Détermine la taille par défaut du papier, par exemple
216 @example
217 -dpaper-size=\"letter\"
218 @end example
219
220 @noindent
221 Veillez à ne pas oublier d'encadrer la valeur par des guillemets
222 échappés ( @code{\"} ).
223 @c Match " in previous line to help context-sensitive editors
224
225
226 @cindex safe, ligne de commande
227
228 @item safe
229 Ne pas avoir une confiance aveugle dans le code @file{@/.ly}.
230
231 Lorsque LilyPond est accessible au travers d'un serveur web, il est
232 @strong{impératif} d'utiliser les options @code{--safe} ou
233 @code{--jail}.  L'option @code{--safe} aura pour effet d'empêcher tout
234 code Scheme inclus de mettre en péril votre installation grâce à quelque
235 chose du style
236
237 @quotation
238 @verbatim
239 #(system "rm -rf /")
240 {
241   c4^#(ly:export (ly:gulp-file "/etc/passwd"))
242 }
243 @end verbatim
244 @end quotation
245
246 L'option @code{-dsafe} forcera l'évaluation, au fil de l'eau et par un
247 module sécurisé, des expressions Scheme contenues dans le fichier
248 source.  Ce module sécuritaire, dérivé du module GUILE @file{safe@/-r5rs},
249 ajoute un certain nombre de fonctions -- listées dans
250 @file{scm/@/safe@/-lily@/.scm} -- à l'API de LilyPond.
251
252 De plus, le mode @emph{safe} ne permet ni l'utilisation de directives
253 @code{\include} ni le recours aux obliques inversées (@emph{backslash})
254 dans les chaînes @TeX{}.
255
256 L'import de variables LilyPond dans du code Scheme n'est pas possible
257 en mode sécuritaire.
258
259 L'option @code{-dsafe} @strong{ne détecte pas} l'utilisation abusive des
260 ressources.  Il est donc possible que le programme finisse par rester
261 sans réponse si on lui envoie une boucle sans fin.  C'est la raison pour
262 laquelle nous recommandons, lorsque LilyPond tourne sur un serveur
263 accessible au public, d'en limiter aussi bien les ressources processeur
264 que mémoire.
265
266 Notez bien que l'utilisation du mode sécuritaire empêchera aussi la
267 compilation d'un certain nombre de fragments LilyPond.  L'option
268 @code{--jail} est dans ce cas une excellente alternative en terme de
269 sécurité, même si elle requiert plus de temps à mettre en place.
270
271
272 @cindex format de sortie, définition
273
274 @item backend
275 Détermine le format de sortie à utiliser par le moteur de traitement.
276 Les types de @code{format} reconnus sont
277 @table @code
278 @item ps
279 @cindex PostScript output
280  pour du PostScript.
281
282 Les fichiers PostScript incluent les polices TTF, Type1 et OTF, et
283 aucune substitution ne sera opérée pour ces fontes.  Si vous utilisez
284 des caractères orientaux, le fichier aura vite fait d'atteindre une
285 taille conséquente.
286
287
288 @item eps
289 @cindex Postscript encapsulé
290 @cindex EPS (Encapsulated PostScript)
291  pour du PostScript encapsulé.
292
293 Chaque page (système) fera l'objet d'un fichier @file{EPS} particulier,
294 sans fontes, auquel sera associé un fichier @file{EPS} qui, lui,
295 contiendra toutes les pages (systèmes) et les fontes.
296
297 Notez qu'il s'agit du mode que @command{lilypond-book} utilise par défaut.
298
299 @item svg
300 @cindex SVG (Scalable Vector Graphics)
301  pour du SVG (@emph{Scalable Vector Graphics}).
302
303 Cette option permet de créer un fichier SVG par page, sans incorporation
304 des fontes.  Nous vous recommandons d'installer les fontes Century
305 Schoolbook comprises dans le paquetage LilyPond afin d'obtenir le
306 meilleur rendu possible.  Sous UNIX, il suffit de les recopier, à partir
307 du répertoire @file{/usr/share/lilypond/VERSION/fonts/otf/}, dans
308 @file{~/.fonts/}.  Les fichiers SVG alors générés devraient être
309 lisibles par votre éditeur SVG habituel.
310
311 @item scm
312 @cindex Scheme dump
313  pour une recopie brute des commandes Scheme internes de formatage.
314
315 @item null
316  permet de ne pas générer de partition imprimable.  Cette option est
317  équivalente à @code{-dno-print-pages}.
318
319 @end table
320
321 Exemple : @code{lilypond -dbackend=svg @var{monfichier}.ly}
322
323
324 @item preview
325 @cindex preview, ligne de commande
326 Génère un fichier comprenant le titrage et le premier système.  S'il
327 existe plusieurs sections @code{\bookpart}, ce fichier contiendra les
328 titrage et premier système de chacun des @code{\bookpart}.  Cette
329 option fonctionne pour les moteurs de traitement @code{ps}, @code{eps}
330 et @code{svg}.
331
332
333 @item print-pages
334 Génère l'intégralité des pages de la partition.  L'option
335 @code{-dno-print-pages} est particulièrement utile lorsqu'utilisée
336 conjointement avec l'option @code{-dpreview}.
337
338 @end table
339
340
341
342 @item -h,--help
343 Affiche un résumé des commandes.
344
345
346 @item -H,--header=@var{CHAMP}
347 Recopie le champ d'entête dans le fichier @file{RACINE.@var{CHAMP}}.
348
349
350 @item --include, -I=@var{répertoire}
351 @cindex recherche de fichier
352 @cindex search path
353
354 Ajoute @var{répertoire} au chemin de recherche pour les inclusions.
355
356 Vous pouvez mentionner plusieurs fois l'option @code{-I}, auquel cas le
357 la recherche commencera dans le premier répertoire inclus et, si le
358 fichier en question ne s'y trouve pas, les répertoires suivants seront
359 examinés l'un après l'autre.
360
361
362 @item -i,--init=@var{fichier}
363 Définit @var{fichier} (par défaut @file{init@/.ly}) en tant que fichier
364 d'initialisation.
365
366
367 @item -o,--output=@var{FICHIER} ou @var{RÉP}
368 @cindex répertoire de destination
369 @cindex fichier de destination
370
371 Détermine le nom par défaut du fichier résultant à @var{FICHIER}@tie{};
372 lorsque l'argument @var{RÉP} correspond à un répertoire déjà existant,
373 c'est là que les fichiers résultants seront déposés.  Le suffixe adéquat
374 sera ajouté (p.ex. @file{@/.pdf} pour du pdf) dans tous les cas.
375
376
377 @cindex PostScript output
378
379 @item --ps
380 Génère du PostScript.
381
382
383 @cindex Portable Network Graphics (PNG) output
384
385 @item --png
386 Génère une image par page, au format PNG@tie{}; ceci sous-entend
387 l'utilisation de @code{--ps}.  La résolution de l'image, en DPI, peut se
388 régler en ajoutant par exemple
389 @example
390 -dresolution=110
391 @end example
392
393
394 @cindex Portable Document Format (PDF) output
395
396 @item --pdf
397 Génère du PDF.  Ceci sous-entend l'utilisation de @code{--ps}.
398
399
400 @item -j,--jail=@var{user},@var{group},@var{jail},@var{dir}
401 Lance @command{lilypond} dans un environnement protégé.
402
403 L'option @code{--jail} est une alternative qui offre plus de flexibilité
404 que l'option @code{--safe} lorsque LilyPond est installé sur un serveur
405 web ou traite des fichiers externes.
406
407 L'option @code{--jail} va détourner la racine de @command{lilypond} sur
408 @code{jail} juste avant d'effectuer la compilation à proprement parler.
409 L'utilisateur et le groupe sont modifiés en conséquence, et le
410 répertoire en cours devient @code{dir}.  Ces réglages assurent -- du
411 moins en théorie -- l'impossibilité de s'échapper de la cellule.  Notez
412 cependant que, pour que l'option @code{--jail} soit fonctionnelle,
413 @code{lilypond} doit être lancé en tant qu'administrateur -- ce qui se
414 réalise aisément à l'aide de la commande @command{sudo}.
415
416 La création d'un environnement sécurisé requiert quelques précautions
417 dans la mesure où LilyPond doit disposer de tout ce dont il a besoin
418 pour compiler le fichier source @strong{à l'intérieur de la cellule}.
419 L'ermitage, avant d'être viable, requiert donc les étapes
420 suivantes@tie{}:
421
422 @table @asis
423 @item Création d'un système de fichiers indépendant
424 L'intérêt d'un système de fichiers dédié à LilyPond réside dans le fait
425 qu'on peut le brider à l'aide des options @code{noexec}, @code{nodev} et
426 @code{nosuid}.  Il sera de fait impossible de lancer des exécutables ou
427 d'écrire sur un périphérique à partir de LilyPond.  Si vous n'avez pas
428 l'intention de créer un tel système sur une partition séparée, vous
429 pouvez avoir recours à un pseudo-périphérique (@emph{loop device}) monté
430 à partir d'un simple fichier de taille raisonnable.  D'autre part, le
431 recours à un système de fichiers indépendant permet de limiter l'espace
432 dévolu à LilyPond.
433
434 @item Création d'un utilisateur spécifique
435 L'utilisation de LilyPond au sein de la cellule devrait être réservé à
436 un utilisateur aux droits restreints.  Il faudra donc créer un
437 utilisateur et un groupe spécifiques -- disons @code{lily}/@code{lily}
438 -- qui n'aura accès en écriture qu'à un unique répertoire déterminé par
439 la valeur de @var{dir}.
440
441 @item Agencement des lieux
442 LilyPond a besoin d'un certain nombre de fichiers pour pouvoir tourner
443 correctement.  Ces fichiers devront donc tous se retrouver dans
444 l'environnement protégé, distribués selon la même arborescence que dans
445 le système d'origine.  Ainsi l'intégralité de l'installation de LilyPond
446 (en principe @file{/usr/share/lilypond}) doit y être dupliquée.
447
448 En cas de problème, lancer LilyPond en utilisant @code{strace} devrait
449 vous permettre de déterminer quels fichiers manquent à l'appel.
450
451 @item Lancement de LilyPond
452 Dans un environnement protégé monté avec l'option @code{noexec}, il est
453 impossible de lancer un quelconque programme extérieur.  LilyPond ne
454 saurait donc avoir recours à un moteur de traitement qui le mettrait
455 dans cette situation.  Comme nous l'avons vu plus haut, LilyPond sera
456 lancé avec les privilèges de l'administrateur -- privilèges qu'il perdra
457 aussitôt --, ce qui peut nécessiter le recours à la commande
458 @code{sudo}.  Il est par ailleurs judicieux de limiter le temps
459 processeur aloué à LilyPond -- grâce à @command{ulimit@tie{}-t} par
460 exemple -- ainsi que, si votre système le permet, la taille de la
461 mémoire.
462 @end table
463
464
465 @item -v,--version
466 Affiche le numéro de version.
467
468
469 @item -V,--verbose
470 Active le mode verbeux@tie{}: affichage de l'intégralité du chemin
471 d'accès de chaque fichier, et information des temps de traitement.
472
473
474 @item -w,--warranty
475 Affiche les informations de garantie appliquables à GNU LilyPond -- il
476 est livré @strong{SANS GARANTIE}@tie{}!
477 @end table
478
479
480 @node Variables d'environnement
481 @unnumberedsubsec Variables d'environnement
482 @translationof Environment variables
483
484 @cindex LANG
485 @cindex LILYPOND_DATADIR
486
487 @command{lilypond} reconnaît les variables d'environnement
488 suivantes@tie{}:
489 @table @code
490 @item LILYPOND_DATADIR
491 Cette variable spécifie le répertoire où seront recherchés par défaut
492 les différentes versions des messages ainsi qu'un certain nombre de
493 fichiers nécessaires au traitement.  Il devrait contenir les
494 sous-répertoires @file{ly/}, @file{ps/}, @file{tex/}, etc.
495
496 @item LANG
497 Cette variable détermine la langue dans laquelle seront émis les
498 messages.
499
500 @item LILYPOND_GC_YIELD
501 Cette variable permet d'ajuster l'empreinte mémoire et le rendement de
502 la machine.  Il s'agit en fait d'un pourcentage d'allocation de
503 mémoire@tie{}: lorsqu'il est élevé, le programme favorisera
504 l'utilisation de la mémoire@tie{}; une faible valeur consommera plus de
505 temps processeur.  Par défaut, cette valeur est fixée à@tie{}@code{70}.
506
507 @end table
508
509
510 @node Exécution de LilyPond en mode protégé
511 @unnumberedsubsec Exécution de LilyPond en mode protégé
512 @translationof LilyPond in chroot jail
513
514 Paramétrer un serveur afin qu'il puisse faire fonctionner LilyPond en
515 mode protégé sur un pseudo-périphérique est une tâche sensible.  Les
516 différentes étapes à suivre sont répertoriées ci-dessous.  Les exemples
517 qu'elle comportent proviennent d'une distribution Linux Ubuntu et
518 nécessiteront l'utilisation de @code{sudo} autant que de besoin.
519
520 @itemize
521
522 @item Installation des paquetages nécessaires@tie{}: LilyPond, GhostScript et
523 ImageMagick.
524
525 @item Création de l'utilisateur @code{lily}:
526
527 @example
528 adduser lily
529 @end example
530
531 @noindent
532 Ceci, par la même occasion, créera un groupe spécifique pour
533 l'utilisateur @code{lily} ainsi que son répertoire personnel
534 @code{/home/lily}.
535
536 @item Création, dans le répertoire personnel de l'utilisateur
537 @code{lily}, d'un espace agissant en tant que système de fichiers@tie{}:
538
539 @example
540 dd if=/dev/zero of=/home/lily/loopfile bs=1k count= 200000
541 @end example
542
543 @noindent
544 Cette commande a créé un fichier de 200@tie{}MB utilisable par le
545 @qq{système protégé}.
546
547 @item Création d'un pseudo-périphérique, génération d'un système de
548 fichiers et chargement de celui-ci, puis création d'un répertoire
549 accessible en écriture pour l'utilisateur @code{lily}@tie{}:
550
551 @example
552 mkdir /mnt/lilyloop
553 losetup /dev/loop0 /home/lily/loopfile
554 mkfs -t ext3 /dev/loop0 200000
555 mount -t ext3 /dev/loop0 /mnt/lilyloop
556 mkdir /mnt/lilyloop/lilyhome
557 chown lily /mnt/lilyloop/lilyhome
558 @end example
559
560 @item Affectation, au niveau configuration du serveur, de
561 @code{/mnt/lilyloop} en tant que JAIL et @code{/lilyhome} en tant que
562 DIR.
563
564 @item Création d'une arborescence, dans l'espace protégé, et recopie de
565 tous les fichiers nécessaires -- voir le script plus loin.
566
567 Le recours à l'utilitaire @code{sed} permet de créer les commandes de
568 copie de tout ce qui est nécessaire à un exécutable@tie{}:
569
570 @example
571 for i in "/usr/local/lilypond/usr/bin/lilypond" "/bin/sh" "/usr/bin/;  \
572   do ldd $i | sed 's/.*=> \/\(.*\/\)\([^(]*\).*/mkdir -p \1 \&\&  \
573     cp -L \/\1\2 \1\2/' | sed 's/\t\/\(.*\/\)\(.*\) (.*)$/mkdir -p  \
574       \1 \&\& cp -L \/\1\2 \1\2/' | sed '/.*=>.*/d'; done
575 @end example
576
577 @end itemize
578
579 @subheading Exemple de script fonctionnel en 32-bit sur Ubuntu 8.04
580
581 @example
582 #!/bin/sh
583 ## les réglages par défaut
584
585 username=lily
586 home=/home
587 loopdevice=/dev/loop0
588 jaildir=/mnt/lilyloop
589 # le préfixe (sans slash au début !)
590 lilyprefix=usr/local
591 # le répertoire du système où lilypond est installé
592 lilydir=/$lilyprefix/lilypond/
593
594 userhome=$home/$username
595 loopfile=$userhome/loopfile
596 adduser $username
597 dd if=/dev/zero of=$loopfile bs=1k count=200000
598 mkdir $jaildir
599 losetup $loopdevice $loopfile
600 mkfs -t ext3 $loopdevice 200000
601 mount -t ext3 $loopdevice $jaildir
602 mkdir $jaildir/lilyhome
603 chown $username $jaildir/lilyhome
604 cd $jaildir
605
606 mkdir -p bin usr/bin usr/share usr/lib usr/share/fonts $lilyprefix tmp
607 chmod a+w tmp
608
609 cp -r -L $lilydir $lilyprefix
610 cp -L /bin/sh /bin/rm bin
611 cp -L /usr/bin/convert /usr/bin/gs usr/bin
612 cp -L /usr/share/fonts/truetype usr/share/fonts
613
614 # la formule magique de recopie des biblothèques
615 for i in "$lilydir/usr/bin/lilypond" "$lilydir/usr/bin/guile" "/bin/sh"  \
616   "/bin/rm" "/usr/bin/gs" "/usr/bin/convert"; do ldd $i | sed 's/.*=>  \
617     \/\(.*\/\)\([^(]*\).*/mkdir -p \1 \&\& cp -L \/\1\2 \1\2/' | sed  \
618       's/\t\/\(.*\/\)\(.*\) (.*)$/mkdir -p \1 \&\& cp -L \/\1\2 \1\2/'  \
619         | sed '/.*=>.*/d'; done | sh -s
620
621 # les fichiers partagés pour ghostscript...
622       cp -L -r /usr/share/ghostscript usr/share
623 # les fichiers partagés pour ImageMagick
624       cp -L -r /usr/lib/ImageMagick* usr/lib
625
626 ### Partant du principe que test.ly est dans /mnt/lilyloop/lilyhome,
627 ### on devrait pouvoir lancer :
628 ### Attention : /$lilyprefix/bin/lilypond est un script qui
629 ### définit LD_LIBRARY_PATH - c'est primordial
630       /$lilyprefix/bin/lilypond -jlily,lily,/mnt/lilyloop,/lilyhome test.ly
631 @end example
632
633
634 @node Messages d'erreur
635 @section Messages d'erreur
636 @translationof Error messages
637
638 @cindex erreur, messages
639
640 Différents messages d'erreur sont susceptibles d'apparaître au cours de
641 la compilation d'un fichier@tie{}:
642
643 @table @emph
644
645 @item Warning -- Avertissement
646 @cindex warning
647 @cindex avertissement
648 Ce type de message est émis lorsque LilyPond détecte quelque chose de
649 suspect.  Si vous avez demandé quelque chose qui sort de l'ordinaire,
650 vous saurez probablement ce à quoi il est fait référence et ignorerez de
651 tels messages sans remord.  Néanmoins, les messages d'avertissement
652 indiquent la plupart du temps une incohérence dans le fichier source.
653
654 @item Error -- Erreur
655 @cindex error
656 LilyPond a détecté une erreur.  L'étape en cours, qu'il s'agisse de
657 l'analyse, de l'interprétation des données ou bien du formatage, sera
658 menée à son terme, puis LilyPond s'arrêtera.
659
660 @item Fatal error -- Erreur fatale
661 @cindex fatal error
662 LilyPond est confronté à une anomalie bloquante.  Ceci ne se produit que
663 très rarement, et la plupart du temps en raison d'une installation
664 défectueuse des fontes.
665
666 @item Scheme error -- Erreur Scheme
667 @cindex trace, Scheme
668 @cindex call trace
669 @cindex Scheme error
670 Les erreurs qui interviennent lors de l'exécution de code Scheme sont
671 gérées par l'interpréteur Scheme.  L'utilisation du mode verbeux
672 (options @code{-V} ou @code{--verbose}) vous permettra de localiser
673 l'appel de fonction délictueux.
674
675 @item Programming error -- Erreur de programmation
676 @cindex Programming error
677 @cindex Erreur de programmation
678 LilyPond est confronté à une incohérence interne.  Ce type de message
679 est destiné à venir en aide aux développeurs et débogueurs.  En règle
680 générale, vous pouvez tout simplement les ignorer.  Parfois, il y en a
681 tant qu'ils masquent ce qui pourrait vous intéresser@dots{}
682
683 @item Aborted (core dumped) -- Abandon
684 @cindex Aborted (core dumped)
685 Ce type de message indique que LilyPond a planté en raison d'une grave
686 erreur de programmation.  La survenance d'un tel message est considérée
687 comme de la plus haute importance.  Si vous y étiez confronté,
688 transmettez un rapport de bogue.
689 @end table
690
691 @cindex errors, message format
692 Lorsque l'avertissement ou l'erreur est directement lié au fichier
693 source, le message est libellé sous la forme
694
695 @example
696 @var{fichier}:@var{ligne}:@var{colonne}: @var{message}
697 @var{contenu de la ligne litigieuse}
698 @end example
699
700 Un saut de ligne est placé dans la ligne de code, indiquant l'endroit
701 précis du problème, comme ici@tie{}:
702
703 @example
704 test.ly:2:19: erreur: n'est pas une durée: 5
705   @{ c'4 e'
706            5 g' @}
707 @end example
708
709 Notez que ces coordonnées constituent l'approximation au mieux par
710 LilyPond dans le code ayant déclenché l'avertissement ou l'erreur.  En
711 règle générale, erreurs et avertissement surviennent lorsque LilyPond
712 rencontre quelque chose d'inattendu.  Lorsque la ligne indiquée ne vous
713 semble pas comporter d'élément litigieux, remontez de quelques lignes
714 dans votre code.
715
716 Vous trouverez d'autres informations sur les erreurs au chapitre
717 @ref{Quelques erreurs des plus courantes}.
718
719
720 @node Quelques erreurs des plus courantes
721 @section Quelques erreurs des plus courantes
722 @translationof Common errors
723
724 Les conditions amenant aux erreurs qui suivent sont fréquentes, bien
725 qu'elles ne soient pas évidentes ni facilement localisables.  Nous
726 espérons que ces explications vous aideront à les résoudre plus
727 facilement.
728
729
730 @menu
731 * La musique déborde de la page::
732 * Apparition d'une portée supplémentaire::
733 * Erreur renvoyant à ../ly/init.ly::
734 * Message d'erreur Unbound variable %::
735 * Message d'erreur FT_Get_Glyph_Name::
736 @end menu
737
738 @node La musique déborde de la page
739 @unnumberedsubsec La musique déborde de la page
740 @translationof Music runs off the page
741
742 Lorsque la musique s'épanche au delà de la marge droite ou bien semble
743 anormalement comprimée, la raison en est le plus souvent une note à la
744 durée erronée@tie{}; cela finit par provoquer le débordement de la
745 dernière note d'une mesure.  Rien ne s'oppose à ce que la dernière note
746 d'une mesure ne s'arrête avant la barre de mesure@tie{}; on considère
747 simplement qu'elle se prolonge sur la mesure suivante.  Des débordements
748 à répétition finissent par générer une musique comprimée ou qui sort de
749 la page, pour la simple et bonne raison que les sauts de ligne
750 automatiques ne peuvent intervenir qu'à la fin d'une mesure complète,
751 autrement dit lorsque toutes les notes sont terminées avant la fin de la
752 mesure.
753
754 @warning{Une durée erronée peut empêcher les sauts de ligne, ce qui
755 conduit à une musique compressée, voire à un débordement de la page.}
756
757 Une erreur de durée sera bien plus facilement localisable si vous
758 positionnez régulièrement des contrôles de barre de mesure -- voir
759 @ruser{Vérification des limites et numéros de mesure}.
760
761 Si vous tenez absolument à enchainer de tels débordements, vous devrez
762 insérer des barres de mesure invisibles là où vous souhaitez positionner
763 un saut de ligne.  Consultez le chapitre @ruser{Barres de mesure} pour
764 plus de détails.
765
766
767 @node Apparition d'une portée supplémentaire
768 @unnumberedsubsec Apparition d'une portée supplémentaire
769 @translationof An extra staff appears
770
771 Lorsque les contextes ne sont pas créés explicitement par la commande
772 @code{\new}, ils le seront si la commande à exécuter n'est pas censée
773 s'appliquer au contexte en cours.  Pour des partitions simples, le fait
774 que les contextes soient automatiquement créés rend bien des services,
775 et c'est d'ailleurs le cas pour la majorité des exemples contenus dans
776 les manuels de LilyPond.  Cependant, la création implicite d'un contexte
777 peut aboutir à l'apparition d'une portée @qq{parasite}.  On s'attend par
778 exemple, en lisant le code qui suit, à ce que toutes les têtes de notes
779 soient en rouge, alors que le résultat nous présente deux portées et que
780 les notes, placées sur la portée inférieure, restent en noir.
781
782 @lilypond[quote,verbatim,relative=2]
783 \override Staff.NoteHead #'color = #red
784 \new Staff { a }
785 @end lilypond
786
787 Étant donné qu'aucun contexte @code{Staff} n'existe lorsque la
788 dérogation est introduite, LilyPond le crée implicitement pour lui
789 appliquer la directive considérée.  Survient alors la commande
790 @w{@code{\new Staff}} qui, à son tour, crée une nouvelle portée pour
791 contenir les notes qui suivent.  Voici la syntaxe correcte pour obtenir
792 ces notes en rouge@tie{}:
793
794 @lilypond[quote,verbatim,relative=2]
795 \new Staff {
796   \override Staff.NoteHead #'color = #red
797   a
798 }
799 @end lilypond
800
801 Autre exemple : la présence d'une commande @code{\relative} à
802 l'intérieur d'une section @code{\repeat} génèrera obligatoirement une
803 portée intempestive.  Cela tient au fait que la commande @code{\repeat}
804 va créer deux blocs @code{\relative} qui, chacun à leur tour, créeront
805 implicitement un bloc @code{Staff} assorti d'un bloc @code{Voice}.
806
807 @lilypond[quote,verbatim]
808 \repeat unfold 2 \relative { c d e f }
809 @end lilypond
810
811 La manière adéquate de procéder consiste à inverser les commandes
812 @code{\repeat} et @code{\relative}, comme ceci@tie{}:
813
814 @lilypond[quote,verbatim]
815 \relative {
816   \repeat unfold 2 { c d e f }
817 }
818 @end lilypond
819
820
821 @node Erreur renvoyant à ../ly/init.ly
822 @unnumberedsubsec Erreur renvoyant à @code{../ly/init.ly}
823 @translationof Apparent error in ../ly/init.ly
824
825 Certains messages d'erreur relatifs à une erreur de syntaxe dans le
826 fichier @file{@/.@/./@/ly/@/init@/.ly} peuvent survenir lorsque le fichier est mal
827 formaté.  Cela se produit notamment lors d'un défaut de parité de
828 bornages ou de guillemets.
829
830 L'erreur la plus courante est la simple omission d'une accolade
831 fermante (@code{@}} à la fin du bloc @code{Score}.  La solution est
832 évidente en pareil cas@tie{}: il suffit de vérifier que le bloc
833 @code{Score} est bien clôturé.  La structure des fichiers LilyPond est
834 abordée plus en détails au chapitre
835 @rlearning{Organisation des fichiers LilyPond}. C'est la raison pour
836 laquelle nous vous invitons à utiliser un éditeur de texte qui prenne en
837 charge le contrôle de parité des parenthèses, crochets et accolades afin
838 de vous éviter de telles erreurs.
839
840 Lorsqu'il s'agit d'un guillemet fermant (@code{"}) omis, le message
841 d'erreur devrait vous indiquer un numéro de ligne avoisinant.  L'erreur
842 se situe la plupart du temps une ou deux lignes au-dessus de celle
843 indiquée.
844
845
846 @node Message d'erreur Unbound variable %
847 @unnumberedsubsec Message d'erreur « Unbound variable % »
848 @translationof Error message Unbound variable %
849
850 Ce message d'erreur, qu'il apparaisse sur le terminal ou en fin de
851 fichier journal, est associé à un message du type @qq{GUILE a signalé
852 une erreur @dots{}}. Il survient à chaque fois qu'un commentaire
853 @emph{LilyPond} est indûment placé dans une routine @emph{Scheme}.
854
855 Un commentaire LilyPond est introduit par le signe pourcent (@code{%})
856 et ne doit en aucun cas se trouver dans une routine Scheme.  En Scheme,
857 les commentaires s'introduisent par un point-virgule (@code{;}).
858
859
860 @node Message d'erreur FT_Get_Glyph_Name
861 @unnumberedsubsec Message d'erreur « FT_Get_Glyph_Name »
862 @translationof Error message FT_Get_Glyph_Name
863
864 Ce message d'erreur, qu'il apparaisse sur le terminal ou en fin de
865 fichier journal, survient lorsqu'un fichier source contient des
866 caractères non ASCII et qu'il n'a pas été enregistré avec un encodage
867 UTF-8.  Pour plus de détails, reportez-vous au chapitre
868 @ruser{Codage du texte}.
869