1 @c -*- coding: utf-8; mode: texinfo; documentlanguage: fr -*-
4 Translation of GIT committish: 8cce5dd067a8a2bab508f5abebc3955db8837bbf
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 « ligne de commande », nous entendons l'interface de commande du
51 système. Les utilisateurs de Windows seront certainement plus familiers
52 des termes « fenêtre DOS » ou « invite de commande ». Quant aux
53 utilisateurs de MacOS X, ils connaissent assurément les termes
54 « console » et « terminal ». Les paramétrages spécifiques au système
55 MacOS font l'objet d'un @rwebnamed{MacOS X,chapitre particulier}.
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.
63 * Lancement de LilyPond::
64 * Options basiques de lilypond::
65 * Options avancées de lilypond::
66 * Variables d'environnement::
67 * Exécution de LilyPond en mode protégé::
71 @node Lancement de LilyPond
72 @unnumberedsubsec Lancement de LilyPond
73 @translationof Invoking LilyPond
75 L'exécutable @command{lilypond} en ligne de commande se lance ainsi :
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 ; 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 Utilisation de LilyPond avec les fonctionnalités standard de l'interpréteur
112 @translationof Using LilyPond with standard shell features
114 Dans la mesure où LilyPond est une application qui fonctionne en ligne
115 de commande, les fonctionnalités de l'interpréteur utilisé pour lancer
116 LilyPond peuvent se révéler utiles.
125 traitera tous les fichiers LilyPond présents dans le répertoire en
128 Rediriger, par exemple dans un fichier, ce qui est émis à l'écran peut
132 lilypond fichier.ly 1> stdout.log
134 lilypond fichier.ly 2> stderr.log
136 lilypond fichier.ly &> tous.log
140 redirigeront respectivement le « verbiage normal », les erreurs ou tout,
141 dans un fichier texte.
143 Consultez avant tout la documentation de votre interpréteur habituel
144 -- terminal, console, etc. -- pour vérifier qu'il prend en charge les
145 options dans cette syntaxe.
147 Voici comment traiter un jeu de fichiers répartis dans un répertoire
148 donné ainsi que tous ses différents sous-répertoires. Les fichiers
149 résultants seront regroupés dans le répertoire à partir duquel la
150 commande a été exécutée, non selon l'emplacement des fichiers sources.
153 find . -name '*.ly' -exec lilypond '@{@}' \;
157 Cette commande, bien qu'effective uniquement dans un terminal, devrait
158 être fonctionnelle aussi pour les utilisateurs de MacOS X.
160 Les utilisateurs de windows utiliseront l'instruction
163 forfiles /s /M *.ly /c "cmd /c lilypond @@file"
167 dans l'@code{interpréteur de commandes}, qui se trouve normalement sous
168 @code{Démarrer > Accessoires > Interpréteur de commandes} ou, pour la
169 version 8, en faisant une recherche sur « interpréteur de commande ».
171 Par ailleurs, il est possible de spécifier de manière explicite le chemin
172 d'accès au dossier comportant des sous-répertoires où se trouvent les
173 fichiers sources, à l'aide de l'option @code{/p} :
176 forfiles /s /p C:\Documents\MesPartitions /M *.ly /c "cmd /c lilypond @@file"
179 Dans le cas où ce chemin d'accès comporte des espaces, l'intégralité de
180 ce chemin devra être borné par des guillemets informatiques :
183 forfiles /s /p "C:\Documents\Mes Partitions" /M *.ly /c "cmd /c lilypond @@file"
187 @node Options basiques de lilypond
188 @unnumberedsubsec Options basiques de @command{lilypond}
189 @translationof Basic command line options for LilyPond
191 @cindex lancement de @command{lilypond}
192 @cindex ligne de commande, options pour @command{lilypond}
193 @cindex options, ligne de commande
197 Différentes options sont disponibles en ligne de commande :
204 Les fichiers PDF générés peuvent être beaucoup plus lourd que la normale
205 selon le degré d'optimisation des fontes. Néanmoins, lorsque plusieurs
206 fichiers PDF sont inclus dans un document @code{pdftex}, @code{xetex} ou
207 @code{luatex}, ils peuvent faire l'objet d'un traitement supplémentaire
208 par @code{ghostscript} afin de fusionner les données de fontes
209 redondantes et ainsi obtenir un fichier PDF @emph{significativement}
213 lilypond -b monfichier
216 Puis lancer @code{ghostscript} :
219 gs -q -sDEVICE=pdfwrite -o gsout.pdf monfichier.pdf
222 @code{pdfsizeopt.py} vient alors en complément pour optimiser encore la
226 pdfsizeopt.py --use-multivalent=no gsout.pdf final.pdf
230 @item -d, --define-default=@var{variable}=@var{valeur}
231 Voir @ref{Options avancées de lilypond}.
233 @cindex Scheme, évaluation d'expression
234 @cindex expression Scheme, évaluation
235 @item -e, --evaluate=@var{expr}
236 Évalue l'expression Scheme @var{expr} avant d'analyser tout fichier
237 @file{.ly}. Lorsque vous spécifiez l'option @option{-e} à plusieurs
238 reprises, l'évaluation sera faite en séquence.
240 Dans la mesure où l'expression est évaluée par le module
241 @code{guile-user}, vous devrez, dès lors que @var{expr} utilise des
242 définitions, spécifier
245 lilypond -e '(define-public a 42)'
249 en ligne de commande, et ajouter la ligne
252 #(use-modules (guile-user))
256 en tête de votre fichier @file{.ly}.
258 @warning{Les utilisateurs de Windows doivent utiliser des guillemets
259 doubles @code{"} en lieu et place des guillemets simples @code{'}.}
260 @c Match " in context-sensitive editors
262 @cindex sortie, format
263 @cindex format de sortie
264 @item -f, --format=@var{format}
265 Détermine le format à produire. Il peut s'agir de @code{ps}, @code{pdf}
268 Exemple : @code{lilypond -fpng @var{monfichier}.ly}
271 Affiche un résumé des commandes.
273 @item -H, --header=@var{CHAMP}
274 Recopie le champ d'entête dans le fichier @file{RACINE.@var{CHAMP}}.
276 @item -i, --init=@var{fichier}
277 Définit @var{fichier} (par défaut @file{init.ly}) en tant que fichier
280 @cindex recherche de fichier
281 @cindex chemin de recherche
282 @item -I, --include=@var{répertoire}
283 Ajoute @var{répertoire} au chemin de recherche pour les inclusions.
285 Vous pouvez mentionner plusieurs fois l'option @option{-I}, auquel cas
286 la recherche commencera dans le premier répertoire inclus et, si le
287 fichier en question ne s'y trouve pas, les répertoires suivants seront
288 examinés l'un après l'autre.
290 @cindex chroot jail, fonctionnement
291 @item -j, --jail=@var{user},@var{group},@var{jail},@var{dir}
292 Lance @command{lilypond} dans un environnement protégé.
294 L'option @option{--jail} est une alternative qui offre plus de
295 flexibilité que l'option @option{--safe} lorsque LilyPond est installé
296 sur un serveur web ou traite des fichiers externes -- voir
297 @ref{Options avancées de lilypond}.
299 L'option @option{--jail} va détourner la racine de @command{lilypond}
300 sur @var{jail} juste avant d'effectuer la compilation à proprement
301 parler. L'utilisateur et le groupe sont modifiés en conséquence, et le
302 répertoire en cours devient @var{dir}. Ces réglages assurent -- du
303 moins en théorie -- l'impossibilité de s'échapper de la cellule. Notez
304 cependant que, pour que l'option @option{--jail} soit fonctionnelle,
305 @command{lilypond} doit être lancé en tant qu'administrateur -- ce qui
306 se réalise aisément à l'aide de la commande @command{sudo}.
308 La création d'un environnement sécurisé requiert quelques précautions
309 dans la mesure où LilyPond doit disposer de tout ce dont il a besoin
310 pour compiler le fichier source @strong{à l'intérieur de la cellule}.
311 L'ermitage, avant d'être viable, requiert donc les étapes
316 @item Création d'un système de fichiers indépendant
317 L'intérêt d'un système de fichiers dédié à LilyPond réside dans le fait
318 qu'on peut le brider à l'aide des options @code{noexec}, @code{nodev} et
319 @code{nosuid}. Il sera de fait impossible de lancer des exécutables ou
320 d'écrire sur un périphérique à partir de LilyPond. Si vous n'avez pas
321 l'intention de créer un tel système sur une partition séparée, vous
322 pouvez avoir recours à un pseudo-périphérique (@emph{loop device}) monté
323 à partir d'un simple fichier de taille raisonnable. D'autre part, le
324 recours à un système de fichiers indépendant permet de limiter l'espace
327 @item Création d'un utilisateur spécifique
328 L'utilisation de LilyPond au sein de la cellule devrait être réservé à
329 un utilisateur aux droits restreints. Il faudra donc créer un
330 utilisateur et un groupe spécifiques -- disons
331 @w{@code{lily}/@code{lily}} -- qui n'aura accès en écriture qu'à un
332 unique répertoire déterminé par la valeur de @var{dir}.
334 @item Agencement des lieux
335 LilyPond a besoin d'un certain nombre de fichiers pour pouvoir tourner
336 correctement. Ces fichiers devront donc tous se retrouver dans
337 l'environnement protégé, distribués selon la même arborescence que dans
338 le système d'origine. Ainsi l'intégralité de l'installation de LilyPond
339 (en principe @file{/usr/share/lilypond}) doit y être dupliquée.
341 En cas de problème, lancer LilyPond en utilisant @command{strace}
342 devrait vous permettre de déterminer quels fichiers manquent à l'appel.
344 @item Lancement de LilyPond
345 Dans un environnement protégé monté avec l'option @code{noexec}, il
346 est impossible de lancer un quelconque programme extérieur. LilyPond ne
347 saurait donc avoir recours à un moteur de traitement qui le mettrait
348 dans cette situation. Comme nous l'avons vu plus haut, LilyPond sera
349 lancé avec les privilèges de l'administrateur -- privilèges qu'il perdra
350 aussitôt --, ce qui peut nécessiter le recours à la commande
351 @code{sudo}. Il est par ailleurs judicieux de limiter le temps
352 processeur alloué à LilyPond -- grâce à @command{ulimit -t} par
353 exemple -- ainsi que, si votre système le permet, la taille de la
354 mémoire. Voir aussi @ref{Exécution de LilyPond en mode protégé}.
358 @cindex verbosité, définir le degré de
359 @item -l, --loglevel=@var{DEGRÉ}
360 Règle le niveau de verbosité des messages console à @var{DEGRÉ}. Les
361 différentes valeurs sont :
365 Aucun verbiage, même pas les messages d'erreur.
368 Uniquement les messages d'erreur ; pas de message d'avertissement
372 Messages d'avertissement ou d'erreur ; pas d'information de
376 Information de progression basique (réussite) et avertissements ou
380 Toutes les informations de progression, avertissements et erreurs.
382 @item INFO (par défaut)
383 Informations de progression, avertissements et erreurs, ainsi que
384 d'autres informations relatives à l'exécution.
387 Tout ce qui peut être affiché, y compris le verbiage utile au débogage.
392 @cindex répertoire de destination
393 @cindex fichier de destination
394 @item -o, --output=@var{FICHIER} ou @var{RÉPERTOIRE}
395 Détermine le nom par défaut du fichier résultant à @var{FICHIER} ;
396 lorsque l'argument @var{RÉPERTOIRE} correspond à un répertoire déjà
397 existant, c'est là que les fichiers résultants seront déposés. Le
398 suffixe adéquat sera ajouté (par ex. @code{.pdf} pour du pdf) dans tous
401 @cindex PostScript, output
402 @cindex PS (PostScript), output
404 Génère du PostScript.
406 @cindex Portable Network Graphics (PNG), output
407 @cindex PNG (Portable Network Graphics), output
409 Génère une image par page, au format PNG ; ceci sous-entend
410 l'utilisation de @option{--ps}. La résolution de l'image, en DPI, peut
411 se régler en ajoutant par exemple
416 @cindex Portable Document Format (PDF), output
417 @cindex PDF (Portable Document Format), output
419 Génère du PDF. Ceci sous-entend l'utilisation de @option{--ps}.
422 Affiche le numéro de version.
425 Active le mode verbeux : affichage de l'intégralité du chemin
426 d'accès de chaque fichier, et information des temps de traitement.
429 Affiche les informations de garantie applicables à GNU LilyPond -- il
430 est livré @strong{SANS GARANTIE} !
435 @node Options avancées de lilypond
436 @unnumberedsubsec Options avancées de @command{lilypond}
437 @translationof Advanced command line options for LilyPond
441 @item -d@var{[nom-option]}=@var{[valeur]}, --define-default=@var{[nom-option]}=@var{[valeur]}
442 Affecte la valeur Scheme @var{valeur} à l'option interne
443 @var{nom-option} du programme.
449 En l'absence de @var{valeur}, le programme utilisera @var{#t}.
450 Préfixer @var{nom-option} d'un @code{no-} vous permet de
451 désactiver une option. Ainsi,
453 @cindex point and click, ligne de commande
454 @cindex pointer-cliquer, ligne de commande
467 @noindent Voici les différentes options disponibles, ainsi que leur
470 @multitable @columnfractions .33 .16 .51
471 @item @strong{Symbole}
473 @tab @strong{Observations}
476 @item @code{anti-alias-factor}
478 @tab Adopte une résolution supérieure (selon le facteur donné),puis
479 réduit au niveau du résultat afin d'éviter les @qq{distorsions} des
482 @item @code{aux-files}
484 @tab Génère les fichiers @code{.tex}, @code{.texi} et @code{.count}
485 pour le moteur de rendu @code{EPS}.
489 @tab Détermine le format de sortie à utiliser par le moteur de
490 traitement. Les fichiers PostScript (format par défaut) incluent les
491 fontes @code{TTF}, @code{Type1} et @code{OTF}, et aucune substitution ne
492 sera opérée pour ces fontes. Si vous utilisez des jeux de caractères
493 orientaux, le fichier aura vite fait d'atteindre une taille conséquente.
497 @tab Génère du PostScript encapsulé. Chaque page (système) fera l'objet
498 d'un fichier @file{EPS} particulier, sans fontes, auquel sera associé un
499 fichier @file{EPS} qui, lui, contiendra toutes les pages (systèmes) et
500 les fontes. Notez qu'il s'agit du mode que @command{lilypond-book}
505 @tab Ne génère aucun fichier imprimable. Cette option est équivalente à
506 @code{-dno-print-pages}.
510 @tab Recopie littéralement les commandes Scheme internes de formatage.
514 @tab Génère du @emph{Scalable Vector Graphics}. Cette option permet de
515 créer un fichier SVG par page. Dans la mesure où aucune information
516 concernant les fontes n'est incorporée, elles devront être installées
517 afin d'obtenir le meilleur rendu possible. Il est préférable de ne pas
518 recourir aux « alias de police » ni aux listes de fontes si le
519 visionneur de fichier SVG ne peut le traîter correctement. L'option
520 @code{svg-woff} -- voir ci-après -- permet d'utiliser les fontes woff
525 @strong{Note à propos du moteur SVG :}
526 Les polices par défaut de LilyPond -- @code{LilyPond Serif},
527 @code{LilyPond Sans Serif} et @code{LilyPond Monospace} -- ne sont que
528 des alias au niveau local. Le recours au moteur SVG requiert donc que
529 ces polices par défaut soient explicitement définies :
535 (make-pango-font-tree "TeX Gyre Schola"
538 (/ staff-height pt 20)))
543 Voir aussi @ruser{Choix des fontes par défaut}.
545 @multitable @columnfractions .33 .16 .51
546 @item @code{check-internal-types}
548 @tab Vérifie qu'à chaque propriété est bien affecté un type.
550 @item @code{clip-systems}
552 @tab Extrait des fragments musicaux d'une partition. Ceci requiert que
553 la fonction @code{clip-regions} a été définie au sein du bloc
554 @code{\layout} -- voir @ruser{Extraction de fragments musicaux}. Bien
555 entendu, aucun fragment ne sera extrait si l'on utilise l'option
556 @option{-dno-print-pages}
560 @tab Détermine le préfixe des fichiers de données (lecture seule).
562 @item @code{debug-gc}
564 @tab Génère une copie brute de la mémoire, aux fins de débogage.
566 @item @code{debug-gc-assert-parsed-dead}
568 @tab Pour débogage de la mémoire : s'assure que toute référence à
569 des objets analysés est effacée. Il s'agit d'une option interne qui
570 est automatiquement activée par l'option @code{`-ddebug-gc'}.
572 @item @code{debug-lexer}
574 @tab Débogage de l'analyseur lexical @emph{flex}.
576 @item @code{debug-page-breaking-scoring}
578 @tab Purge les calculs des configurations de saut de page.
580 @item @code{debug-parser}
582 @tab Débogage de l'analyseur @emph{bison}.
584 @item @code{debug-property-callbacks}
586 @tab Débogage des chaînes de @emph{callback} cycliques.
588 @item @code{debug-skylines}
590 @tab Débogage des lignes d'horizon.
592 @item @code{delete-intermediate-files}
594 @tab Supprime les fichiers @code{.ps} inutiles crées lors de la
597 @item @code{dump-cpu-profile}
599 @tab Génère une copie brute des informations de timing (dépend du
602 @item @code{dump-profile}
604 @tab Génère une copie brute de la mémoire et des temps de traitement
607 @item @code{dump-signatures}
609 @tab Génère une copie des signatures de chaque système. Cette option
610 est utilisée pour les tests de régression.
612 @item @code{eps-box-padding}
614 @tab Décale le bord gauche du typon EPS d'une valeur donnée en
617 @item @code{gs-load-fonts}
619 @tab Charge les fontes grâce à Ghostscript.
621 @item @code{gs-load-lily-fonts}
623 @tab Limite les fontes chargées par Ghostscript aux seules fontes
628 @tab Travaille silencieusement, et redirige tout le verbiage dans un
633 @strong{Note à l'attention des utilisateurs de Windows :} toutes
634 les informations concernant le traitement apparaissent au fur et à
635 mesure dans l'interpréteur de commandes lorsque vous lancez le programme
636 @code{lilypond.exe}, à l'inverse de @w{@code{lilypond-windows.exe}} qui
637 vous renvoie simplement la main. L'option @option{-dgui} vous permettra
638 alors de rediriger ces informations dans un fichier journal.
640 @multitable @columnfractions .33 .16 .51
643 @tab Affiche cette aide.
645 @item @code{include-book-title-preview}
647 @tab Inclut les titres de l'ouvrage dans les images de prévisualisation.
649 @item @code{include-eps-fonts}
651 @tab Inclut les fontes dans chaque fichier EPS contenant un système.
653 @item @code{include-settings}
655 @tab Inclut un fichier contenant les réglages globaux. Ce fichier sera
656 inclus avant traitement de la partition.
658 @item @code{job-count}
660 @tab Traite plusieurs fichiers en parallèle, selon le nombre de
663 @item @code{log-file}
664 @tab @code{#f [fichier]}
665 @tab Fournir @code{TOTO} en second argument redirigera la sortie dans le
666 fichier journal @code{TOTO.log}.
668 @item @code{max-markup-depth}
670 @tab Profondeur maximale de l'arborescence de @emph{markups}. Si un
671 @emph{markup} était plus profond, part du principe qu'on aboutira pas,
672 émet un avertissement et renvoie alors un @emph{markup} vide.
674 @item @code{midi-extension}
676 @tab Détermine l'extension par défaut des fichiers MIDI, selon la chaîne
679 @item @code{music-strings-to-paths}
681 @tab Convertit les chaînes textuelles en chemins lorsque les glyphes
682 font partie d'une fonte musicale.
684 @cindex paper-size, ligne de commande
685 @item @code{paper-size}
687 @tab Détermine la taille par défaut du papier. Veillez à ne pas oublier
688 d'encadrer la valeur par des guillemets échappés (@code{\"}).
689 @c Match " in context-sensitive editors
691 @item @code{pixmap-format}
693 @tab Détermine le format de sortie en images pixélisées pour
696 @item @code{point-and-click}
698 @tab Ajoute les liens @qq{point & click} à la sortie PDF ou SVG. Voir
699 @ref{Pointer-cliquer}.
701 @cindex format de sortie, définition
702 @cindex preview, ligne de commande
705 @tab Génère une prévisualisation en plus de la sortie normale.
709 Cette option, disponible dans tous les formats de sortie imprimables --
710 @code{pdf}, @code{png}, @code{ps}, @code{eps} et @code{svg} -- génère
711 un fichier de la forme @code{monFichier.preview.extension} comprenant le
712 titrage et le premier système. S'il existe plusieurs sections
713 @code{\book}, @code{\bookpart}, ce fichier contiendra les titrage et
714 premier système de chacun des @code{\book}, @code{\bookpart} et
715 @code{\score}, dès lors que la variable @code{print-all-headers} du bloc
716 @code{\paper} est activée.
718 Pour l'éviter, utilisez conjointement l'une des options
719 @option{-dprint-pages} ou @option{-dno-print-pages} selon vos besoins.
721 @multitable @columnfractions .33 .16 .51
722 @item @code{print-pages}
724 @tab Génère l'intégralité des pages de la partition. L'option
725 @option{-dno-print-pages} est particulièrement utile lorsqu'utilisée
726 conjointement avec l'option @option{-dpreview}.
728 @item @code{profile-property-accesses}
730 @tab Enregistre des statistiques des appels à la fonction
731 @code{get_property()}.
733 @item @code{protected-scheme-parsing}
735 @tab Continue en dépit des erreurs que l'analyseur syntaxique
736 détecterait dans du code Scheme inclus. Lorsque basculé sur @code{#f},
737 stoppe le traitement s'il y a erreur et affiche une trace de la pile.
739 @item @code{read-file-list}
740 @tab @code{#f [fichier]}
741 @tab Spécifie un fichier listant les différents fichiers sources à
744 @item @code{relative-includes}
746 @tab Face à une instruction @code{\include}, recherche les fichiers à
747 inclure relativement à l'endroit où se trouve le fichier en cours de
748 traitement plutôt que par rapport au fichier maître.
750 @item @code{resolution}
752 @tab Détermine, en @code{dpi}, la résolution des pixmaps @code{PNG} à
753 générer selon la valeur donnée.
757 @tab Ne pas avoir une confiance aveugle dans le code @file{.ly}.
761 Lorsque LilyPond est accessible au travers d'un serveur web, il est
762 @strong{impératif} d'utiliser les options @option{--safe} ou
763 @option{--jail}. L'option @option{--safe} aura pour effet d'empêcher
764 tout code Scheme inclus de mettre en péril votre installation grâce à
765 quelque chose du style
769 #(s ystem "rm -rf /") % trop dangeureux à écrire sans faute
771 c4^$(ly:gulp-file "/etc/passwd") % malveillant mais pas destructeur
776 L'option @code{-dsafe} forcera l'évaluation, au fil de l'eau et par un
777 module sécurisé, des expressions Scheme contenues dans le fichier
778 source. Ce module sécuritaire, dérivé du module GUILE @file{safe-r5rs},
779 ajoute un certain nombre de fonctions -- listées dans
780 @file{scm/safe-lily.scm} -- à l'API de LilyPond.
782 De plus, le mode @emph{safe} ne permet ni l'utilisation de directives
783 @code{\include} ni le recours aux obliques inversées (@emph{backslash})
784 dans les chaînes @TeX{}. L'import de variables LilyPond dans du code
785 Scheme n'est pas possible en mode sécurisé.
787 L'option @code{-dsafe} @strong{ne détecte pas} l'utilisation abusive des
788 ressources. Il est donc possible que le programme finisse par rester
789 sans réponse si on lui envoie une boucle sans fin. C'est la raison pour
790 laquelle nous recommandons, lorsque LilyPond tourne sur un serveur
791 accessible au public, d'en limiter aussi bien les ressources processeur
794 Notez bien que l'utilisation du mode sécuritaire empêchera aussi la
795 compilation d'un certain nombre de fragments LilyPond. L'option
796 @code{--jail} est dans ce cas une excellente alternative en terme de
797 sécurité, même si elle requiert plus de temps à mettre en place -- voir
798 @ref{Options basiques de lilypond}.
800 @multitable @columnfractions .33 .16 .51
801 @item @code{separate-log-files}
803 @tab Pour les fichiers @code{FICHIER1.ly}, @code{FICHIER2.ly}, etc.
804 enregistre le déroulement dans les journaux @code{FICHIER1.log},
805 @code{FICHIER2.log}@dots{}
807 @item @code{show-available-fonts}
809 @tab Liste le nom des fontes disponibles.
811 @item @code{strict-infinity-checking}
813 @tab Force le crash en présence des points d'exception de virgule
814 flottante @code{Inf} ou @code{NaN} -- infini ou non-nombre.
816 @item @code{strip-output-dir}
818 @tab Supprime, lors du nommage des fichiers résultant, la partie
819 correspondant au répertoire des fichiers sources.
821 @item @code{strokeadjust}
823 @tab Force l'ajustement des traits PostScript. Cette option trouve
824 toute son utilité pour générer du PDF à partir de PostScript --
825 l'ajustement des traits est en principe automatiquement activé pour les
826 périphériques bitmap à faible résolution. Sans cette option, les
827 visionneurs de PDF ont tendance à ne pas rendre de manière constante
828 l'épaisseur des hampes dans les résolutions habituelles des écrans.
829 Bien que n'affectant pas notoirement la qualité d'impression, cette
830 option accroit notablement la taille des fichiers PDF.
832 @item @code{svg-woff}
834 @tab Utilise, avec le moteur SVG, les fontes @code{woff}.
835 Lorsque celles-ci sont utilisées correctement, nul n'est besoin
836 d'installer les fontes que les fichiers SVG utiliseront dans
837 l'environnement du visionneur. Néanmoins, LilyPond ne dispose pas de
838 fichier de fonte @code{woff} textuelle. La présence du fichier de fonte
839 @code{woff} est un prérequis.
841 @item @code{trace-memory-frequency}
843 @tab Enregistre l'utilisation de la cellule Scheme plusieurs fois par
844 seconde, dans les fichiers @code{FICHIER.stacks} et
845 @code{FICHIER.graph}.
847 @item @code{trace-scheme-coverage}
849 @tab Enregistre la couverture des fichiers Scheme dans @code{FILE.cov}.
853 @tab Passe en mode verbeux, ce qui correspond à un niveau de
854 journalisation @code{DEBUG} (lecture seule).
856 @item @code{warning-as-error}
858 @tab Considère tous les messages d'avertissement et « erreur de
859 programmation » comme étant de véritables erreurs.
863 @node Variables d'environnement
864 @unnumberedsubsec Variables d'environnement
865 @translationof Environment variables
868 @cindex LILYPOND_DATADIR
870 @command{lilypond} reconnaît les variables d'environnement
874 @item LILYPOND_DATADIR
875 Cette variable spécifie le répertoire où seront recherchés par défaut
876 les différentes versions des messages ainsi qu'un certain nombre de
877 fichiers nécessaires au traitement. Il devrait contenir les
878 sous-répertoires @file{ly/}, @file{ps/}, @file{tex/}, etc.
881 Cette variable détermine la langue dans laquelle seront émis les
884 @item LILYPOND_LOGLEVEL
885 Cette variable détermine le niveau par défaut de verbosité. En
886 l'absence de niveau explicite -- autrement dit la ligne de commande ne
887 comporte pas de @option{--loglevel} -- c'est cette valeur qui sera
890 @item LILYPOND_GC_YIELD
891 Cette variable permet d'ajuster l'empreinte mémoire et le rendement de
892 la machine. Il s'agit en fait d'un pourcentage d'allocation de
893 mémoire : lorsqu'il est élevé, le programme favorisera
894 l'utilisation de la mémoire ; une faible valeur consommera plus de
895 temps processeur. Par défaut, cette valeur est fixée à @code{70}.
900 @node Exécution de LilyPond en mode protégé
901 @unnumberedsubsec Exécution de LilyPond en mode protégé
902 @translationof LilyPond in chroot jail
904 Paramétrer un serveur afin qu'il puisse faire fonctionner LilyPond en
905 mode protégé sur un pseudo-périphérique est une tâche sensible. Les
906 différentes étapes à suivre sont répertoriées ci-dessous. Les exemples
907 qu'elle comportent proviennent d'une distribution GNU/Linux Ubuntu et
908 nécessiteront l'utilisation de @code{sudo} autant que de besoin.
912 @item Installation des paquetages nécessaires : LilyPond, Ghostscript et
915 @item Création de l'utilisateur @code{lily} :
922 Ceci, par la même occasion, créera un groupe spécifique pour
923 l'utilisateur @code{lily} ainsi que son répertoire personnel
926 @item Création, dans le répertoire personnel de l'utilisateur
927 @code{lily}, d'un espace agissant en tant que système de fichiers :
930 dd if=/dev/zero of=/home/lily/loopfile bs=1k count= 200000
934 Cette commande a créé un fichier de 200 MB utilisable par le
935 @qq{système protégé}.
937 @item Création d'un pseudo-périphérique, génération d'un système de
938 fichiers et chargement de celui-ci, puis création d'un répertoire
939 accessible en écriture pour l'utilisateur @code{lily} :
943 losetup /dev/loop0 /home/lily/loopfile
944 mkfs -t ext3 /dev/loop0 200000
945 mount -t ext3 /dev/loop0 /mnt/lilyloop
946 mkdir /mnt/lilyloop/lilyhome
947 chown lily /mnt/lilyloop/lilyhome
950 @item Affectation, au niveau configuration du serveur, de
951 @code{/mnt/lilyloop} en tant que JAIL et @code{/lilyhome} en tant que
954 @item Création d'une arborescence, dans l'espace protégé, et recopie de
955 tous les fichiers nécessaires -- voir le script plus loin.
957 Le recours à l'utilitaire @code{sed} permet de créer les commandes de
958 copie de tout ce qui est nécessaire à un exécutable :
961 for i in "/usr/local/lilypond/usr/bin/lilypond" "/bin/sh" "/usr/bin/; \
962 do ldd $i | sed 's/.*=> \/\(.*\/\)\([^(]*\).*/mkdir -p \1 \&\& \
963 cp -L \/\1\2 \1\2/' | sed 's/\t\/\(.*\/\)\(.*\) (.*)$/mkdir -p \
964 \1 \&\& cp -L \/\1\2 \1\2/' | sed '/.*=>.*/d'; done
969 @subheading Exemple de script fonctionnel en 32-bit sur Ubuntu 8.04
973 ## les réglages par défaut
977 loopdevice=/dev/loop0
978 jaildir=/mnt/lilyloop
979 # le préfixe (sans slash au début !)
981 # le répertoire du système où lilypond est installé
982 lilydir=/$lilyprefix/lilypond/
984 userhome=$home/$username
985 loopfile=$userhome/loopfile
987 dd if=/dev/zero of=$loopfile bs=1k count=200000
989 losetup $loopdevice $loopfile
990 mkfs -t ext3 $loopdevice 200000
991 mount -t ext3 $loopdevice $jaildir
992 mkdir $jaildir/lilyhome
993 chown $username $jaildir/lilyhome
996 mkdir -p bin usr/bin usr/share usr/lib usr/share/fonts $lilyprefix tmp
999 cp -r -L $lilydir $lilyprefix
1000 cp -L /bin/sh /bin/rm bin
1001 cp -L /usr/bin/convert /usr/bin/gs usr/bin
1002 cp -L /usr/share/fonts/truetype usr/share/fonts
1004 # la formule magique de recopie des bibliothèques
1005 for i in "$lilydir/usr/bin/lilypond" "$lilydir/usr/bin/guile" "/bin/sh" \
1006 "/bin/rm" "/usr/bin/gs" "/usr/bin/convert"; do ldd $i | sed 's/.*=> \
1007 \/\(.*\/\)\([^(]*\).*/mkdir -p \1 \&\& cp -L \/\1\2 \1\2/' | sed \
1008 's/\t\/\(.*\/\)\(.*\) (.*)$/mkdir -p \1 \&\& cp -L \/\1\2 \1\2/' \
1009 | sed '/.*=>.*/d'; done | sh -s
1011 # les fichiers partagés pour ghostscript...
1012 cp -L -r /usr/share/ghostscript usr/share
1013 # les fichiers partagés pour ImageMagick
1014 cp -L -r /usr/lib/ImageMagick* usr/lib
1016 ### Partant du principe que test.ly est dans /mnt/lilyloop/lilyhome,
1017 ### on devrait pouvoir lancer :
1018 ### Attention : /$lilyprefix/bin/lilypond est un script qui
1019 ### définit LD_LIBRARY_PATH - c'est primordial
1020 /$lilyprefix/bin/lilypond -jlily,lily,/mnt/lilyloop,/lilyhome test.ly
1024 @node Messages d'erreur
1025 @section Messages d'erreur
1026 @translationof Error messages
1028 @cindex erreur, messages
1030 Différents messages d'erreur sont susceptibles d'apparaître au cours de
1031 la compilation d'un fichier :
1035 @item Warning -- Avertissement
1037 @cindex avertissement
1038 Ce type de message est émis lorsque LilyPond détecte quelque chose de
1039 suspect. Si vous avez demandé quelque chose qui sort de l'ordinaire,
1040 vous saurez probablement ce à quoi il est fait référence et ignorerez de
1041 tels messages sans remord. Néanmoins, les messages d'avertissement
1042 indiquent la plupart du temps une incohérence dans le fichier source.
1044 @item Error -- Erreur
1046 LilyPond a détecté une erreur. L'étape en cours, qu'il s'agisse de
1047 l'analyse, de l'interprétation des données ou bien du formatage, sera
1048 menée à son terme, puis LilyPond s'arrêtera.
1050 @item Fatal error -- Erreur fatale
1052 LilyPond est confronté à une anomalie bloquante. Ceci ne se produit que
1053 très rarement, et la plupart du temps en raison d'une installation
1054 défectueuse des fontes.
1056 @item Scheme error -- Erreur Scheme
1057 @cindex trace, Scheme
1059 @cindex Scheme error
1060 Les erreurs qui interviennent lors de l'exécution de code Scheme sont
1061 gérées par l'interpréteur Scheme. L'utilisation du mode verbeux
1062 (options @option{-V} ou @option{--verbose}) vous permettra de localiser
1063 l'appel de fonction délictueux.
1065 @item Programming error -- Erreur de programmation
1066 @cindex Programming error
1067 @cindex Erreur de programmation
1068 LilyPond est confronté à une incohérence interne. Ce type de message
1069 est destiné à venir en aide aux développeurs et débogueurs. En règle
1070 générale, vous pouvez tout simplement les ignorer. Parfois, il y en a
1071 tant qu'ils masquent ce qui pourrait vous intéresser@dots{}
1073 @item Aborted (core dumped) -- Abandon
1074 @cindex Aborted (core dumped)
1075 Ce type de message indique que LilyPond a planté en raison d'une grave
1076 erreur de programmation. La survenance d'un tel message est considérée
1077 comme de la plus haute importance. Si vous y étiez confronté,
1078 transmettez un rapport de bogue.
1081 @cindex errors, message format
1082 Lorsque l'avertissement ou l'erreur est directement lié au fichier
1083 source, le message est libellé sous la forme
1086 @var{fichier}:@var{ligne}:@var{colonne}: @var{message}
1087 @var{contenu de la ligne litigieuse}
1090 Un saut de ligne est placé dans la ligne de code, indiquant l'endroit
1091 précis du problème, comme ici :
1094 test.ly:2:19: erreur: n'est pas une durée: 5
1099 Notez que ces coordonnées constituent l'approximation au mieux par
1100 LilyPond dans le code ayant déclenché l'avertissement ou l'erreur. En
1101 règle générale, erreurs et avertissements surviennent lorsque LilyPond
1102 rencontre quelque chose d'inattendu. Lorsque la ligne indiquée ne vous
1103 semble pas comporter d'élément litigieux, remontez de quelques lignes
1106 Par ailleurs, des diagnostics peuvent être déclenchés à n'importe quel
1107 moment au cours des différentes étapes du traitement. Par exemple,
1108 lorsque certaines parties de la source sont traitées plusieurs fois --
1109 sortie MIDI et sortie imprimable -- ou qu'une même variable musicale est
1110 utilisée dans plusieurs contextes, peut apparaître le même message à
1111 plusieurs reprises. Les diagnostics effectués à une étape avancée du
1112 traitement, tels que les contrôles de mesure, sont aussi susceptibles
1113 d'apparaître plusieurs fois.
1115 Vous trouverez d'autres informations sur les erreurs au chapitre
1116 @ref{Quelques erreurs des plus courantes}.
1119 @node Quelques erreurs des plus courantes
1120 @section Quelques erreurs des plus courantes
1121 @translationof Common errors
1123 Les conditions amenant aux erreurs qui suivent sont fréquentes, bien
1124 qu'elles ne soient pas évidentes ni facilement localisables. Nous
1125 espérons que ces explications vous aideront à les résoudre plus
1129 * La musique déborde de la page::
1130 * Apparition d'une portée supplémentaire::
1131 * Message d'erreur Unbound variable %::
1132 * Message d'erreur FT_Get_Glyph_Name::
1133 * staff-affinities devraient aller en ordre décroissant::
1134 * Message d'erreur unexpected new::
1135 * Cette voix requiert un voiceXx ou un réglage shiftXx::
1139 @node La musique déborde de la page
1140 @unnumberedsubsec La musique déborde de la page
1141 @translationof Music runs off the page
1143 Lorsque la musique s'épanche au delà de la marge droite ou bien semble
1144 anormalement comprimée, la raison en est le plus souvent une note à la
1145 durée erronée ; cela finit par provoquer le débordement de la
1146 dernière note d'une mesure. Rien ne s'oppose à ce que la dernière note
1147 d'une mesure ne s'arrête avant la barre de mesure ; on considère
1148 simplement qu'elle se prolonge sur la mesure suivante. Des débordements
1149 à répétition finissent par générer une musique comprimée ou qui sort de
1150 la page, pour la simple et bonne raison que les sauts de ligne
1151 automatiques ne peuvent intervenir qu'à la fin d'une mesure complète,
1152 autrement dit lorsque toutes les notes sont terminées avant la fin de la
1155 @warning{Une durée erronée peut empêcher les sauts de ligne, ce qui
1156 conduit à une musique compressée, voire à un débordement de la page.}
1158 Une erreur de durée sera bien plus facilement localisable si vous
1159 positionnez régulièrement des contrôles de barre de mesure -- voir
1160 @ruser{Vérification des limites et numéros de mesure}.
1162 Si vous tenez absolument à enchaîner de tels débordements, vous devrez
1163 insérer des barres de mesure invisibles là où vous souhaitez positionner
1164 un saut de ligne. Consultez le chapitre @ruser{Barres de mesure} pour
1168 @node Apparition d'une portée supplémentaire
1169 @unnumberedsubsec Apparition d'une portée supplémentaire
1170 @translationof An extra staff appears
1172 Lorsque les contextes ne sont pas créés explicitement par la commande
1173 @code{\new}, ils le seront si la commande à exécuter n'est pas censée
1174 s'appliquer au contexte en cours. Pour des partitions simples, le fait
1175 que les contextes soient automatiquement créés rend bien des services,
1176 et c'est d'ailleurs le cas pour la majorité des exemples contenus dans
1177 les manuels de LilyPond. Cependant, la création implicite d'un contexte
1178 peut aboutir à l'apparition d'une portée « parasite ». On s'attend par
1179 exemple, en lisant le code qui suit, à ce que toutes les têtes de note
1180 soient en rouge, alors que le résultat nous présente deux portées et que
1181 les notes, placées sur la portée inférieure, restent en noir.
1183 @lilypond[quote,verbatim,fragment]
1184 \override Staff.NoteHead.color = #red
1188 Étant donné qu'aucun contexte @code{Staff} n'existe lorsque la
1189 dérogation est introduite, LilyPond le crée implicitement pour lui
1190 appliquer la directive considérée. Survient alors la commande
1191 @code{\new Staff} qui, à son tour, crée une nouvelle portée pour
1192 contenir les notes qui suivent. Voici la syntaxe correcte pour obtenir
1193 ces notes en rouge :
1195 @lilypond[quote,verbatim]
1197 \override Staff.NoteHead.color = #red
1203 @node Message d'erreur Unbound variable %
1204 @unnumberedsubsec Message d'erreur @code{Unbound variable %}
1205 @translationof Error message Unbound variable %
1207 Ce message d'erreur, qu'il apparaisse sur le terminal ou en fin de
1208 fichier journal, est associé à un message du type @qq{GUILE a signalé
1209 une erreur@dots{}}. Il survient à chaque fois qu'un commentaire
1210 @emph{LilyPond} est indûment placé dans une routine @emph{Scheme}.
1212 Un commentaire LilyPond est introduit par le signe pourcent (@code{%})
1213 et ne doit en aucun cas se trouver dans une routine Scheme. En Scheme,
1214 les commentaires s'introduisent par un point-virgule (@code{;}).
1217 @node Message d'erreur FT_Get_Glyph_Name
1218 @unnumberedsubsec Message d'erreur @code{FT_Get_Glyph_Name}
1219 @translationof Error message FT_Get_Glyph_Name
1221 Ce message d'erreur, qu'il apparaisse sur le terminal ou en fin de
1222 fichier journal, survient lorsqu'un fichier source contient des
1223 caractères non ASCII et qu'il n'a pas été enregistré avec un encodage
1224 UTF-8. Pour plus de détails, reportez-vous au chapitre
1225 @ruser{Caractères spéciaux}.
1228 @node staff-affinities devraient aller en ordre décroissant
1229 @unnumberedsubsec @emph{staff-affinities} devraient aller en ordre décroissant
1230 @translationof Warning staff affinities should only decrease
1232 Cet avertissement est émis lorsque la partition ne comporte pas de
1233 portée, comme par exemple une feuille de chant avec un contexte
1234 @code{ChordName} et un contexte @code{Lyrics}. Ce message disparaîtra
1235 dès lors que vous autoriserez l'un de ces contextes à se comporter comme
1236 une portée, à l'aide de l'instruction
1239 \override VerticalAxisGroup.staff-affinity = ##f
1243 que vous insérerez dès sa création. Pour plus d'information,
1244 reportez-vous à la rubrique
1245 @ruser{Espacement des lignes rattachées à des portées}.
1248 @node Message d'erreur unexpected new
1249 @unnumberedsubsec Message d'erreur unexpected @code{@bs{}new}
1250 @translationof Error message unexpected new
1252 Un bloc @code{\score} ne peut contenir qu'@strong{une seule} expression
1253 musicale. Si, par contre, il comporte plusieurs @code{\new Staff},
1254 @code{\new StaffGroup} ou autres contextes introduits par une commande
1255 @code{\new} qui ne seraient pas bornés par des accolades
1256 @code{@{ @dots{} @}} ou des doubles chevrons @code{<< @dots{} >>} comme
1261 % Invalide ! Génère l'erreur : syntax error, unexpected \new
1262 % en français : erreur de syntaxe : \new inattendu
1263 \new Staff @{ @dots{} @}
1264 \new Staff @{ @dots{} @}
1269 vous obtiendrez ce message d'erreur.
1271 Cette erreur sera évitée dès lors que toutes les instances de
1272 @code{\new} sont bornées par des accolades ou des doubles chevrons.
1274 Des accolades placeront ces clauses @code{\new} en séquence :
1276 @lilypond[quote,verbatim]
1279 \new Staff { a' a' a' a' }
1280 \new Staff { g' g' g' g' }
1286 alors que des doubles chevrons les placeront en parallèle ; autrement
1287 dit, LilyPond les traitera simultanément :
1289 @lilypond[quote,verbatim]
1292 \new Staff { a' a' a' a' }
1293 \new Staff { g' g' g' g' }
1299 @node Cette voix requiert un voiceXx ou un réglage shiftXx
1300 @unnumberedsubsec Cette voix requiert un @code{@bs{}voiceXx} ou un réglage @code{@bs{}shiftXx}
1301 @translationof Warning this voice needs a voiceXx or shiftXx setting
1303 Lorsque des notes affectées à des voix différentes et ayant la même
1304 orientation de hampe interviennent au même instant musical et qu'aucun
1305 décalage spécifique à la voix n'a été spécifié, LilyPond émet
1306 @code{Avertissement : Cette voix requiert un voiceXx ou un réglage
1307 shiftXx} (@emph{warning: this voice needs a \voiceXx or \shiftXx
1308 setting}). Cet avertissement est émis même lorsque ces notes n'ont pas
1309 de hampe visible, comme par exemple des rondes, si les hampes des durées
1310 inférieures à ces même hauteurs avaient la même orientation.
1312 N'oublions pas que l'orientation des hampes dépend de la position des
1313 notes sur la portée à moins que cette orientation n'ait été spécifiée,
1314 par exemple à l'aide d'un @code{\voiceOne} ou autre clause. En pareil
1315 cas, l'avertissement ne sera émis que lorsque les hampes auront la même
1316 orientation, autrement dit lorsque les notes seront dans la même moitié
1319 Le fait de placer les notes dans des voix auxquelles sont attachés
1320 orientation de hampe et décalage, comme @code{\voiceOne} ou autre, peut
1321 permettre d'éviter ces avertissements.
1323 Les notes se trouvant dans des voix au numéro plus élévé --
1324 @code{\voiceThree} ou @code{\voiceFour} -- sont automatiquement décalées
1325 pour éviter que les empilements se chevauchent. Ceci aura pour résultat
1326 de visuellement décaler les notes affublées de hampe sans toutefois
1327 bouger les rondes, hormis dans le cas d'un réel chevauchement ou lorsque
1328 ces voix se croisent (@code{\voiceThree} au dessus de@code{\voiceOne}).
1331 Manuel d'initiation :
1332 @rlearning{Instanciation explicite des voix},
1333 @rlearning{Exemple concret}.
1335 Manuel de notation :
1336 @ruser{Polyphonie sur une portée},
1337 @ruser{Résolution des collisions}.