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