1 @c -*- coding: utf-8; mode: texinfo; documentlanguage: fr -*-
4 Translation of GIT committish: a9d95f320e4b9fe65e0655911ea7b55bf0d10b2b
6 When revising a translation, copy the HEAD committish of the
7 version that you are working on. For details, see the Contributors'
8 Guide, node Updating translation committishes..
13 @c Translators: Jean-Charles Malahieude
14 @c Translation checkers:
16 @node Exécution de lilypond
17 @chapter Exécution de @command{lilypond}
18 @translationof Running lilyPond
20 Ce chapitre passe en revue ce qui se passe lorsque vous lancez LilyPond.
23 * Utilisation habituelle::
24 * Utilisation en ligne de commande::
26 * Quelques erreurs des plus courantes::
29 @node Utilisation habituelle
30 @section Utilisation habituelle
31 @translationof Normal usage
33 La plupart des utilisateurs de LilyPond le font au travers d'une
34 interface graphique (@emph{GUI} pour @emph{graphical user interface}).
35 Si vous ne l'avez pas encore parcouru, lisez le @rlearning{Tutoriel}.
36 Si vous utilisez un éditeur alternatif pour rédiger vos fichiers
37 LilyPond, référez-vous à la documentation de celui-ci.
40 @node Utilisation en ligne de commande
41 @section Utilisation en ligne de commande
42 @translationof Command-line usage
44 Nous nous intéresserons ici aux spécificités de LilyPond employé en
45 ligne de commande. La ligne de commande permet de faire appel à
46 certaines options particulières. D'autre part, certains utilitaires
47 associés, tel que @code{midi2ly}, ne sont disponibles qu'en ligne de
50 Par @qq{ligne de commande}, nous entendons l'interface de commande du
51 système. Les utilisateurs de Windows seront certainement plus familiers
52 des termes @qq{fenêtre DOS} ou @qq{invite de commande}. Quant aux
53 utilisateurs de MacOS X, ils connaissent assurément les termes
54 @qq{console} et @qq{terminal}. Les paramétrages spécifiques au système
55 MacOS font l'objet d'un @rwebnamed{MacOS X,chapitre particulier}.
57 Notre propos n'est pas ici d'expliquer ce qu'est l'interface de
58 commande pour un système informatique ni comment elle fonctionne.
59 Aussi, si vous ne savez de quoi il retourne, nous vous renvoyons aux
60 nombreuses documentations que vous pourrez trouver sur ce sujet.
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 @command{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 Commandes standard de l'interpréteur
112 @translationof Standard shell commands
114 Si votre interpréteur -- terminal, console, etc. -- prend en charge les
115 redirections, les commandes qui suivent vous permettront de
116 judicieusement rediriger les affichages de la console dans un
122 @code{lilypond fichier.ly 1>stdout.log} pour le verbiage normal
125 @code{lilypond fichier.ly 2>stderr.log} pour les messages d'erreur
128 @code{lilypond fichier.ly &>tous.log} pour garder une trace de tout ce
133 Consultez avant tout la documentation de votre interpréteur habituel
134 pour vérifier qu'il prend en charge ces options dans cette syntaxe.
135 Notez bien qu'il s'agit ici de commandes internes à l'interpréteur et
136 qui n'ont rien à voir avec LilyPond.
139 @node Options basiques de lilypond
140 @unnumberedsubsec Options basiques de @command{lilypond}
141 @translationof Basic command line options for LilyPond
143 @cindex lancement de @command{lilypond}
144 @cindex ligne de commande, options pour @command{lilypond}
145 @cindex options, ligne de commande
149 Différentes options sont disponibles en ligne de commande :
153 @item -d, --define-default=@var{variable}=@var{valeur}
154 Voir @ref{Options avancées de lilypond}.
156 @cindex Scheme, évaluation d'expression
157 @cindex expression Scheme, évaluation
158 @item -e, --evaluate=@var{expr}
159 Évalue l'expression Scheme @var{expr} avant d'analyser tout fichier
160 @file{.ly}. Lorsque vous spécifiez l'option @option{-e} à plusieurs
161 reprises, l'évaluation sera faite en séquence.
163 Dans la mesure où l'expression est évaluée par le module
164 @code{guile-user}, vous devrez, dès lors que @var{expr} utilise des
165 définitions, spécifier
168 lilypond -e '(define-public a 42)'
172 en ligne de commande, et ajouter la ligne
175 #(use-modules (guile-user))
179 en tête de votre fichier @file{.ly}.
181 @warning{Les utilisateurs de Windows doivent utiliser des guillemets
182 doubles @code{"} en lieu et place des guillemets simples @code{'}.}
183 @c Match " in context-sensitive editors
185 @cindex sortie, format
186 @cindex format de sortie
187 @item -f, --format=@var{format}
188 Détermine le format à produire. Il peut s'agir de @code{ps}, @code{pdf}
191 Exemple : @code{lilypond -fpng @var{monfichier}.ly}
194 Affiche un résumé des commandes.
196 @item -H, --header=@var{CHAMP}
197 Recopie le champ d'entête dans le fichier @file{RACINE.@var{CHAMP}}.
199 @item -i, --init=@var{fichier}
200 Définit @var{fichier} (par défaut @file{init.ly}) en tant que fichier
203 @cindex recherche de fichier
204 @cindex chemin de recherche
205 @item -I, --include=@var{répertoire}
206 Ajoute @var{répertoire} au chemin de recherche pour les inclusions.
208 Vous pouvez mentionner plusieurs fois l'option @option{-I}, auquel cas
209 la recherche commencera dans le premier répertoire inclus et, si le
210 fichier en question ne s'y trouve pas, les répertoires suivants seront
211 examinés l'un après l'autre.
213 @cindex chroot jail, fonctionnement
214 @item -j, --jail=@var{user},@var{group},@var{jail},@var{dir}
215 Lance @command{lilypond} dans un environnement protégé.
217 L'option @option{--jail} est une alternative qui offre plus de
218 flexibilité que l'option @option{--safe} lorsque LilyPond est installé
219 sur un serveur web ou traite des fichiers externes -- voir
220 @ref{Options avancées de lilypond}.
222 L'option @option{--jail} va détourner la racine de @command{lilypond}
223 sur @var{jail} juste avant d'effectuer la compilation à proprement
224 parler. L'utilisateur et le groupe sont modifiés en conséquence, et le
225 répertoire en cours devient @var{dir}. Ces réglages assurent -- du
226 moins en théorie -- l'impossibilité de s'échapper de la cellule. Notez
227 cependant que, pour que l'option @option{--jail} soit fonctionnelle,
228 @command{lilypond} doit être lancé en tant qu'administrateur -- ce qui
229 se réalise aisément à l'aide de la commande @command{sudo}.
231 La création d'un environnement sécurisé requiert quelques précautions
232 dans la mesure où LilyPond doit disposer de tout ce dont il a besoin
233 pour compiler le fichier source @strong{à l'intérieur de la cellule}.
234 L'ermitage, avant d'être viable, requiert donc les étapes
239 @item Création d'un système de fichiers indépendant
240 L'intérêt d'un système de fichiers dédié à LilyPond réside dans le fait
241 qu'on peut le brider à l'aide des options @code{noexec}, @code{nodev} et
242 @code{nosuid}. Il sera de fait impossible de lancer des exécutables ou
243 d'écrire sur un périphérique à partir de LilyPond. Si vous n'avez pas
244 l'intention de créer un tel système sur une partition séparée, vous
245 pouvez avoir recours à un pseudo-périphérique (@emph{loop device}) monté
246 à partir d'un simple fichier de taille raisonnable. D'autre part, le
247 recours à un système de fichiers indépendant permet de limiter l'espace
250 @item Création d'un utilisateur spécifique
251 L'utilisation de LilyPond au sein de la cellule devrait être réservé à
252 un utilisateur aux droits restreints. Il faudra donc créer un
253 utilisateur et un groupe spécifiques -- disons
254 @w{@code{lily}/@code{lily}} -- qui n'aura accès en écriture qu'à un
255 unique répertoire déterminé par la valeur de @var{dir}.
257 @item Agencement des lieux
258 LilyPond a besoin d'un certain nombre de fichiers pour pouvoir tourner
259 correctement. Ces fichiers devront donc tous se retrouver dans
260 l'environnement protégé, distribués selon la même arborescence que dans
261 le système d'origine. Ainsi l'intégralité de l'installation de LilyPond
262 (en principe @file{/usr/share/lilypond}) doit y être dupliquée.
264 En cas de problème, lancer LilyPond en utilisant @command{strace}
265 devrait vous permettre de déterminer quels fichiers manquent à l'appel.
267 @item Lancement de LilyPond
268 Dans un environnement protégé monté avec l'option @code{noexec}, il
269 est impossible de lancer un quelconque programme extérieur. LilyPond ne
270 saurait donc avoir recours à un moteur de traitement qui le mettrait
271 dans cette situation. Comme nous l'avons vu plus haut, LilyPond sera
272 lancé avec les privilèges de l'administrateur -- privilèges qu'il perdra
273 aussitôt --, ce qui peut nécessiter le recours à la commande
274 @code{sudo}. Il est par ailleurs judicieux de limiter le temps
275 processeur alloué à LilyPond -- grâce à @command{ulimit -t} par
276 exemple -- ainsi que, si votre système le permet, la taille de la
277 mémoire. Voir aussi @ref{Exécution de LilyPond en mode protégé}.
281 @cindex verbosité, définir le degré de
282 @item -l, --loglevel=@var{DEGRÉ}
283 Règle le niveau de verbosité des messages console à @var{DEGRÉ}. Les
284 différentes valeurs sont :
288 Aucun verbiage, même pas les messages d'erreur.
291 Uniquement les messages d'erreur ; pas de message d'avertissement
295 Messages d'avertissement ou d'erreur ; pas d'information de
299 Information de progression basique (réussite) et avertissements ou
303 Toutes les informations de progression, avertissements et erreurs.
305 @item INFO (par défaut)
306 Informations de progression, avertissements et erreurs, ainsi que
307 d'autres informations relatives à l'exécution.
310 Tout ce qui peut être affiché, y compris le verbiage utile au débogage.
315 @cindex répertoire de destination
316 @cindex fichier de destination
317 @item -o, --output=@var{FICHIER} ou @var{RÉPERTOIRE}
318 Détermine le nom par défaut du fichier résultant à @var{FICHIER} ;
319 lorsque l'argument @var{RÉPERTOIRE} correspond à un répertoire déjà
320 existant, c'est là que les fichiers résultants seront déposés. Le
321 suffixe adéquat sera ajouté (par ex. @code{.pdf} pour du pdf) dans tous
324 @cindex PostScript, output
325 @cindex PS (PostScript), output
327 Génère du PostScript.
329 @cindex Portable Network Graphics (PNG), output
330 @cindex PNG (Portable Network Graphics), output
332 Génère une image par page, au format PNG ; ceci sous-entend
333 l'utilisation de @option{--ps}. La résolution de l'image, en DPI, peut
334 se régler en ajoutant par exemple
339 @cindex Portable Document Format (PDF), output
340 @cindex PDF (Portable Document Format), output
342 Génère du PDF. Ceci sous-entend l'utilisation de @option{--ps}.
345 Affiche le numéro de version.
348 Active le mode verbeux : affichage de l'intégralité du chemin
349 d'accès de chaque fichier, et information des temps de traitement.
352 Affiche les informations de garantie applicables à GNU LilyPond -- il
353 est livré @strong{SANS GARANTIE} !
358 @node Options avancées de lilypond
359 @unnumberedsubsec Options avancées de @command{lilypond}
360 @translationof Advanced command line options for LilyPond
364 @item -d@var{[nom-option]}=@var{[valeur]}, --define-default=@var{[nom-option]}=@var{[valeur]}
365 Affecte la valeur Scheme @var{valeur} à l'option interne
366 @var{nom-option} du programme.
372 En l'absence de @var{valeur}, le programme utilisera @var{#t}.
373 Préfixer @var{nom-option} d'un @code{no-} vous permet de
374 désactiver une option. Ainsi,
376 @cindex point and click, ligne de commande
377 @cindex pointer-cliquer, ligne de commande
390 @noindent Voici les différentes options disponibles, ainsi que leur
393 @multitable @columnfractions .33 .16 .51
394 @item @strong{Symbole}
396 @tab @strong{Observations}
399 @item @code{anti-alias-factor}
401 @tab Adopte une résolution supérieure (selon le facteur donné),puis
402 réduit au niveau du résultat afin d'éviter les @qq{distorsions} des
405 @item @code{aux-files}
407 @tab Génère les fichiers @code{.tex}, @code{.texi} et @code{.count}
408 pour le moteur de rendu @code{EPS}.
412 @tab Détermine le format de sortie à utiliser par le moteur de
413 traitement. Les fichiers PostScript (format par défaut) incluent les
414 fontes @code{TTF}, @code{Type1} et @code{OTF}, et aucune substitution ne
415 sera opérée pour ces fontes. Si vous utilisez des jeux de caractères
416 orientaux, le fichier aura vite fait d'atteindre une taille conséquente.
420 @tab Génère du PostScript encapsulé. Chaque page (système) fera l'objet
421 d'un fichier @file{EPS} particulier, sans fontes, auquel sera associé un
422 fichier @file{EPS} qui, lui, contiendra toutes les pages (systèmes) et
423 les fontes. Notez qu'il s'agit du mode que @command{lilypond-book}
428 @tab Ne génère aucun fichier imprimable. Cette option est équivalente à
429 @code{-dno-print-pages}.
433 @tab Génère du@emph{Scalable Vector Graphics}. Cette option permet de
434 créer un fichier @code{SVG} par page, sans incorporation des fontes.
435 Nous vous recommandons d'installer les fontes Century Schoolbook
436 comprises dans le paquetage LilyPond afin d'obtenir le meilleur rendu
437 possible. Sous UNIX, il suffit de les recopier, à partir du répertoire
438 @file{/usr/share/lilypond/VERSION/fonts/otf/}, dans @file{~/.fonts/}.
439 Les fichiers @code{SVG} alors générés devraient être lisibles par votre
440 éditeur SVG habituel. L'option @code{svg-woff} -- voir ci-après --
441 permet d'utiliser les fontes @code{woff} avec le moteur @code{SVG}.
445 @tab Recopie littéralement les commandes Scheme internes de formatage.
447 @item @code{check-internal-types}
449 @tab Vérifie qu'à chaque propriété est bien affecté un type.
451 @item @code{clip-systems}
453 @tab Génère des typons à partir d'une partition.
457 @tab Détermine le préfixe des fichiers de données (lecture seule).
459 @item @code{debug-gc}
461 @tab Génère une copie brute de la mémoire, aux fins de débogage.
463 @item @code{debug-gc-assert-parsed-dead}
465 @tab Pour débogage de la mémoire : s'assure que toute référence à
466 des objets analysés est effacée. Il s'agit d'une option interne qui
467 est automatiquement activée par l'option @code{`-ddebug-gc'}.
469 @item @code{debug-lexer}
471 @tab Débogage de l'analyseur lexical @emph{flex}.
473 @item @code{debug-page-breaking-scoring}
475 @tab Purge les calculs des configurations de saut de page.
477 @item @code{debug-parser}
479 @tab Débogage de l'analyseur @emph{bison}.
481 @item @code{debug-property-callbacks}
483 @tab Débogage des chaînes de @emph{callback} cycliques.
485 @item @code{debug-skylines}
487 @tab Débogage des lignes d'horizon.
489 @item @code{delete-intermediate-files}
491 @tab Supprime les fichiers @code{.ps} inutiles crées lors de la
494 @item @code{dump-cpu-profile}
496 @tab Génère une copie brute des informations de timing (dépend du
499 @item @code{dump-profile}
501 @tab Génère une copie brute de la mémoire et des temps de traitement
504 @item @code{dump-signatures}
506 @tab Génère une copie des signatures de chaque système. Cette option
507 est utilisée pour les tests de régression.
509 @item @code{eps-box-padding}
511 @tab Décale le bord gauche du typon EPS d'une valeur donnée en
514 @item @code{gs-load-fonts}
516 @tab Charge les fontes grâce à Ghostscript.
518 @item @code{gs-load-lily-fonts}
520 @tab Limite les fontes chargées par Ghostscript aux seules fontes
525 @tab Travaille silencieusement, et redirige tout le verbiage dans un
530 @strong{Note à l'attention des utilisateurs de Windows :} toutes
531 les informations concernant le traitement apparaissent au fur et à
532 mesure dans l'interpréteur de commandes lorsque vous lancez le programme
533 @code{lilypond.exe}, à l'inverse de @w{@code{lilypond-windows.exe}} qui
534 vous renvoie simplement la main. L'option @option{-dgui} vous permettra
535 alors de rediriger ces informations dans un fichier journal.
537 @multitable @columnfractions .33 .16 .51
540 @tab Affiche cette aide.
542 @item @code{include-book-title-preview}
544 @tab Inclut les titres de l'ouvrage dans les images de prévisualisation.
546 @item @code{include-eps-fonts}
548 @tab Inclut les fontes dans chaque fichier EPS contenant un système.
550 @item @code{include-settings}
552 @tab Inclut un fichier contenant les réglages globaux. Ce fichier sera
553 inclus avant traitement de la partition.
555 @item @code{job-count}
557 @tab Traite plusieurs fichiers en parallèle, selon le nombre de
560 @item @code{log-file}
561 @tab @code{#f [fichier]}
562 @tab Fournir @code{TOTO} en second argument redirigera la sortie dans le
563 fichier journal @code{TOTO.log}.
565 @item @code{max-markup-depth}
567 @tab Profondeur maximale de l'arborescence de @emph{markups}. Si un
568 @emph{markup} était plus profond, part du principe qu'on aboutira pas,
569 émet un avertissement et renvoie alors un @emph{markup} vide.
571 @item @code{midi-extension}
573 @tab Détermine l'extension par défaut des fichiers MIDI, selon la chaîne
576 @item @code{music-strings-to-paths}
578 @tab Convertit les chaînes textuelles en chemins lorsque les glyphes
579 font partie d'une fonte musicale.
581 @cindex paper-size, ligne de commande
582 @item @code{paper-size}
584 @tab Détermine la taille par défaut du papier. Veillez à ne pas oublier
585 d'encadrer la valeur par des guillemets échappés (@code{\"}).
586 @c Match " in context-sensitive editors
588 @item @code{pixmap-format}
590 @tab Détermine le format de sortie en images pixélisées pour
593 @item @code{point-and-click}
595 @tab Ajoute les liens @qq{point & click} à la sortie @code{PDF}. Voir
596 @ref{Pointer-cliquer}.
598 @cindex format de sortie, définition
599 @cindex preview, ligne de commande
602 @tab Génère une prévisualisation en plus de la sortie normale.
606 Cette option, disponible dans tous les formats de sortie imprimables --
607 @code{pdf}, @code{png}, @code{ps}, @code{eps} et @code{svg} -- génère
608 un fichier de la forme @code{monFichier.preview.extension} comprenant le
609 titrage et le premier système. S'il existe plusieurs sections
610 @code{\book}, @code{\bookpart}, ce fichier contiendra les titrage et
611 premier système de chacun des @code{\book}, @code{\bookpart} et
612 @code{\score}, dès lors que la variable @code{print-all-headers} du bloc
613 @code{\paper} est activée.
615 Pour l'éviter, utilisez conjointement l'une des options
616 @option{-dprint-pages} ou @option{-dno-print-pages} selon vos besoins.
618 @multitable @columnfractions .33 .16 .51
619 @item @code{print-pages}
621 @tab Génère l'intégralité des pages de la partition. L'option
622 @option{-dno-print-pages} est particulièrement utile lorsqu'utilisée
623 conjointement avec l'option @option{-dpreview}.
625 @item @code{profile-property-accesses}
627 @tab Enregistre des statistiques des appels à la fonction
628 @code{get_property()}.
630 @item @code{protected-scheme-parsing}
632 @tab Continue en dépit des erreurs que l'analyseur syntaxique
633 détecterait dans du code Scheme inclus. Lorsque basculé sur @code{#f},
634 stoppe le traitement s'il y a erreur et affiche une trace de la pile.
636 @item @code{read-file-list}
637 @tab @code{#f [fichier]}
638 @tab Spécifie un fichier listant les différents fichiers sources à
641 @item @code{relative-includes}
643 @tab Face à une instruction @code{\include}, recherche les fichiers à
644 inclure relativement à l'endroit où se trouve le fichier en cours de
645 traitement plutôt que par rapport au fichier maître.
647 @item @code{resolution}
649 @tab Détermine, en @code{dpi}, la résolution des pixmaps @code{PNG} à
650 générer selon la valeur donnée.
654 @tab Ne pas avoir une confiance aveugle dans le code @file{.ly}.
658 Lorsque LilyPond est accessible au travers d'un serveur web, il est
659 @strong{impératif} d'utiliser les options @option{--safe} ou
660 @option{--jail}. L'option @option{--safe} aura pour effet d'empêcher
661 tout code Scheme inclus de mettre en péril votre installation grâce à
662 quelque chose du style
668 c4^$(ly:gulp-file "/etc/passwd")
673 L'option @code{-dsafe} forcera l'évaluation, au fil de l'eau et par un
674 module sécurisé, des expressions Scheme contenues dans le fichier
675 source. Ce module sécuritaire, dérivé du module GUILE @file{safe-r5rs},
676 ajoute un certain nombre de fonctions -- listées dans
677 @file{scm/safe-lily.scm} -- à l'API de LilyPond.
679 De plus, le mode @emph{safe} ne permet ni l'utilisation de directives
680 @code{\include} ni le recours aux obliques inversées (@emph{backslash})
681 dans les chaînes @TeX{}. L'import de variables LilyPond dans du code
682 Scheme n'est pas possible en mode sécurisé.
684 L'option @code{-dsafe} @strong{ne détecte pas} l'utilisation abusive des
685 ressources. Il est donc possible que le programme finisse par rester
686 sans réponse si on lui envoie une boucle sans fin. C'est la raison pour
687 laquelle nous recommandons, lorsque LilyPond tourne sur un serveur
688 accessible au public, d'en limiter aussi bien les ressources processeur
691 Notez bien que l'utilisation du mode sécuritaire empêchera aussi la
692 compilation d'un certain nombre de fragments LilyPond. L'option
693 @code{--jail} est dans ce cas une excellente alternative en terme de
694 sécurité, même si elle requiert plus de temps à mettre en place -- voir
695 @ref{Options basiques de lilypond}.
697 @multitable @columnfractions .33 .16 .51
698 @item @code{separate-log-files}
700 @tab Pour les fichiers @code{FICHIER1.ly}, @code{FICHIER2.ly}, etc.
701 enregistre le déroulement dans les journaux @code{FICHIER1.log},
702 @code{FICHIER2.log}@dots{}
704 @item @code{show-available-fonts}
706 @tab Liste le nom des fontes disponibles.
708 @item @code{strict-infinity-checking}
710 @tab Force le crash en présence des points d'exception de virgule
711 flottante @code{Inf} ou @code{NaN} -- infini ou non-nombre.
713 @item @code{strip-output-dir}
715 @tab Supprime, lors du nommage des fichiers résultant, la partie
716 correspondant au répertoire des fichiers sources.
718 @item @code{svg-woff}
720 @tab Utilise, avec le moteur SVG, les fontes @code{woff}.
722 @item @code{trace-memory-frequency}
724 @tab Enregistre l'utilisation de la cellule Scheme plusieurs fois par
725 seconde, dans les fichiers @code{FICHIER.stacks} et
726 @code{FICHIER.graph}.
728 @item @code{trace-scheme-coverage}
730 @tab Enregistre la couverture des fichiers Scheme dans @code{FILE.cov}.
734 @tab Passe en mode verbeux, ce qui correspond à un niveau de
735 journalisation @code{DEBUG} (lecture seule).
737 @item @code{warning-as-error}
739 @tab Considère tous les messages d'avertissement et @qq{erreur de
740 programmation} comme étant de véritables erreurs.
744 @node Variables d'environnement
745 @unnumberedsubsec Variables d'environnement
746 @translationof Environment variables
749 @cindex LILYPOND_DATADIR
751 @command{lilypond} reconnaît les variables d'environnement
755 @item LILYPOND_DATADIR
756 Cette variable spécifie le répertoire où seront recherchés par défaut
757 les différentes versions des messages ainsi qu'un certain nombre de
758 fichiers nécessaires au traitement. Il devrait contenir les
759 sous-répertoires @file{ly/}, @file{ps/}, @file{tex/}, etc.
762 Cette variable détermine la langue dans laquelle seront émis les
765 @item LILYPOND_LOGLEVEL
766 Cette variable détermine le niveau par défaut de verbosité. En
767 l'absence de niveau explicite -- autrement dit la ligne de commande ne
768 comporte pas de @option{--loglevel} -- c'est cette valeur qui sera
771 @item LILYPOND_GC_YIELD
772 Cette variable permet d'ajuster l'empreinte mémoire et le rendement de
773 la machine. Il s'agit en fait d'un pourcentage d'allocation de
774 mémoire : lorsqu'il est élevé, le programme favorisera
775 l'utilisation de la mémoire ; une faible valeur consommera plus de
776 temps processeur. Par défaut, cette valeur est fixée à @code{70}.
781 @node Exécution de LilyPond en mode protégé
782 @unnumberedsubsec Exécution de LilyPond en mode protégé
783 @translationof LilyPond in chroot jail
785 Paramétrer un serveur afin qu'il puisse faire fonctionner LilyPond en
786 mode protégé sur un pseudo-périphérique est une tâche sensible. Les
787 différentes étapes à suivre sont répertoriées ci-dessous. Les exemples
788 qu'elle comportent proviennent d'une distribution GNU/Linux Ubuntu et
789 nécessiteront l'utilisation de @code{sudo} autant que de besoin.
793 @item Installation des paquetages nécessaires : LilyPond, Ghostscript et
796 @item Création de l'utilisateur @code{lily} :
803 Ceci, par la même occasion, créera un groupe spécifique pour
804 l'utilisateur @code{lily} ainsi que son répertoire personnel
807 @item Création, dans le répertoire personnel de l'utilisateur
808 @code{lily}, d'un espace agissant en tant que système de fichiers :
811 dd if=/dev/zero of=/home/lily/loopfile bs=1k count= 200000
815 Cette commande a créé un fichier de 200 MB utilisable par le
816 @qq{système protégé}.
818 @item Création d'un pseudo-périphérique, génération d'un système de
819 fichiers et chargement de celui-ci, puis création d'un répertoire
820 accessible en écriture pour l'utilisateur @code{lily} :
824 losetup /dev/loop0 /home/lily/loopfile
825 mkfs -t ext3 /dev/loop0 200000
826 mount -t ext3 /dev/loop0 /mnt/lilyloop
827 mkdir /mnt/lilyloop/lilyhome
828 chown lily /mnt/lilyloop/lilyhome
831 @item Affectation, au niveau configuration du serveur, de
832 @code{/mnt/lilyloop} en tant que JAIL et @code{/lilyhome} en tant que
835 @item Création d'une arborescence, dans l'espace protégé, et recopie de
836 tous les fichiers nécessaires -- voir le script plus loin.
838 Le recours à l'utilitaire @code{sed} permet de créer les commandes de
839 copie de tout ce qui est nécessaire à un exécutable :
842 for i in "/usr/local/lilypond/usr/bin/lilypond" "/bin/sh" "/usr/bin/; \
843 do ldd $i | sed 's/.*=> \/\(.*\/\)\([^(]*\).*/mkdir -p \1 \&\& \
844 cp -L \/\1\2 \1\2/' | sed 's/\t\/\(.*\/\)\(.*\) (.*)$/mkdir -p \
845 \1 \&\& cp -L \/\1\2 \1\2/' | sed '/.*=>.*/d'; done
850 @subheading Exemple de script fonctionnel en 32-bit sur Ubuntu 8.04
854 ## les réglages par défaut
858 loopdevice=/dev/loop0
859 jaildir=/mnt/lilyloop
860 # le préfixe (sans slash au début !)
862 # le répertoire du système où lilypond est installé
863 lilydir=/$lilyprefix/lilypond/
865 userhome=$home/$username
866 loopfile=$userhome/loopfile
868 dd if=/dev/zero of=$loopfile bs=1k count=200000
870 losetup $loopdevice $loopfile
871 mkfs -t ext3 $loopdevice 200000
872 mount -t ext3 $loopdevice $jaildir
873 mkdir $jaildir/lilyhome
874 chown $username $jaildir/lilyhome
877 mkdir -p bin usr/bin usr/share usr/lib usr/share/fonts $lilyprefix tmp
880 cp -r -L $lilydir $lilyprefix
881 cp -L /bin/sh /bin/rm bin
882 cp -L /usr/bin/convert /usr/bin/gs usr/bin
883 cp -L /usr/share/fonts/truetype usr/share/fonts
885 # la formule magique de recopie des bibliothèques
886 for i in "$lilydir/usr/bin/lilypond" "$lilydir/usr/bin/guile" "/bin/sh" \
887 "/bin/rm" "/usr/bin/gs" "/usr/bin/convert"; do ldd $i | sed 's/.*=> \
888 \/\(.*\/\)\([^(]*\).*/mkdir -p \1 \&\& cp -L \/\1\2 \1\2/' | sed \
889 's/\t\/\(.*\/\)\(.*\) (.*)$/mkdir -p \1 \&\& cp -L \/\1\2 \1\2/' \
890 | sed '/.*=>.*/d'; done | sh -s
892 # les fichiers partagés pour ghostscript...
893 cp -L -r /usr/share/ghostscript usr/share
894 # les fichiers partagés pour ImageMagick
895 cp -L -r /usr/lib/ImageMagick* usr/lib
897 ### Partant du principe que test.ly est dans /mnt/lilyloop/lilyhome,
898 ### on devrait pouvoir lancer :
899 ### Attention : /$lilyprefix/bin/lilypond est un script qui
900 ### définit LD_LIBRARY_PATH - c'est primordial
901 /$lilyprefix/bin/lilypond -jlily,lily,/mnt/lilyloop,/lilyhome test.ly
905 @node Messages d'erreur
906 @section Messages d'erreur
907 @translationof Error messages
909 @cindex erreur, messages
911 Différents messages d'erreur sont susceptibles d'apparaître au cours de
912 la compilation d'un fichier :
916 @item Warning -- Avertissement
918 @cindex avertissement
919 Ce type de message est émis lorsque LilyPond détecte quelque chose de
920 suspect. Si vous avez demandé quelque chose qui sort de l'ordinaire,
921 vous saurez probablement ce à quoi il est fait référence et ignorerez de
922 tels messages sans remord. Néanmoins, les messages d'avertissement
923 indiquent la plupart du temps une incohérence dans le fichier source.
925 @item Error -- Erreur
927 LilyPond a détecté une erreur. L'étape en cours, qu'il s'agisse de
928 l'analyse, de l'interprétation des données ou bien du formatage, sera
929 menée à son terme, puis LilyPond s'arrêtera.
931 @item Fatal error -- Erreur fatale
933 LilyPond est confronté à une anomalie bloquante. Ceci ne se produit que
934 très rarement, et la plupart du temps en raison d'une installation
935 défectueuse des fontes.
937 @item Scheme error -- Erreur Scheme
938 @cindex trace, Scheme
941 Les erreurs qui interviennent lors de l'exécution de code Scheme sont
942 gérées par l'interpréteur Scheme. L'utilisation du mode verbeux
943 (options @option{-V} ou @option{--verbose}) vous permettra de localiser
944 l'appel de fonction délictueux.
946 @item Programming error -- Erreur de programmation
947 @cindex Programming error
948 @cindex Erreur de programmation
949 LilyPond est confronté à une incohérence interne. Ce type de message
950 est destiné à venir en aide aux développeurs et débogueurs. En règle
951 générale, vous pouvez tout simplement les ignorer. Parfois, il y en a
952 tant qu'ils masquent ce qui pourrait vous intéresser@dots{}
954 @item Aborted (core dumped) -- Abandon
955 @cindex Aborted (core dumped)
956 Ce type de message indique que LilyPond a planté en raison d'une grave
957 erreur de programmation. La survenance d'un tel message est considérée
958 comme de la plus haute importance. Si vous y étiez confronté,
959 transmettez un rapport de bogue.
962 @cindex errors, message format
963 Lorsque l'avertissement ou l'erreur est directement lié au fichier
964 source, le message est libellé sous la forme
967 @var{fichier}:@var{ligne}:@var{colonne}: @var{message}
968 @var{contenu de la ligne litigieuse}
971 Un saut de ligne est placé dans la ligne de code, indiquant l'endroit
972 précis du problème, comme ici :
975 test.ly:2:19: erreur: n'est pas une durée: 5
980 Notez que ces coordonnées constituent l'approximation au mieux par
981 LilyPond dans le code ayant déclenché l'avertissement ou l'erreur. En
982 règle générale, erreurs et avertissements surviennent lorsque LilyPond
983 rencontre quelque chose d'inattendu. Lorsque la ligne indiquée ne vous
984 semble pas comporter d'élément litigieux, remontez de quelques lignes
987 Vous trouverez d'autres informations sur les erreurs au chapitre
988 @ref{Quelques erreurs des plus courantes}.
991 @node Quelques erreurs des plus courantes
992 @section Quelques erreurs des plus courantes
993 @translationof Common errors
995 Les conditions amenant aux erreurs qui suivent sont fréquentes, bien
996 qu'elles ne soient pas évidentes ni facilement localisables. Nous
997 espérons que ces explications vous aideront à les résoudre plus
1001 * La musique déborde de la page::
1002 * Apparition d'une portée supplémentaire::
1003 * Message d'erreur Unbound variable %::
1004 * Message d'erreur FT_Get_Glyph_Name::
1005 * staff-affinities devraient aller en ordre décroissant::
1006 * Message d'erreur unexpected new::
1010 @node La musique déborde de la page
1011 @unnumberedsubsec La musique déborde de la page
1012 @translationof Music runs off the page
1014 Lorsque la musique s'épanche au delà de la marge droite ou bien semble
1015 anormalement comprimée, la raison en est le plus souvent une note à la
1016 durée erronée ; cela finit par provoquer le débordement de la
1017 dernière note d'une mesure. Rien ne s'oppose à ce que la dernière note
1018 d'une mesure ne s'arrête avant la barre de mesure ; on considère
1019 simplement qu'elle se prolonge sur la mesure suivante. Des débordements
1020 à répétition finissent par générer une musique comprimée ou qui sort de
1021 la page, pour la simple et bonne raison que les sauts de ligne
1022 automatiques ne peuvent intervenir qu'à la fin d'une mesure complète,
1023 autrement dit lorsque toutes les notes sont terminées avant la fin de la
1026 @warning{Une durée erronée peut empêcher les sauts de ligne, ce qui
1027 conduit à une musique compressée, voire à un débordement de la page.}
1029 Une erreur de durée sera bien plus facilement localisable si vous
1030 positionnez régulièrement des contrôles de barre de mesure -- voir
1031 @ruser{Vérification des limites et numéros de mesure}.
1033 Si vous tenez absolument à enchaîner de tels débordements, vous devrez
1034 insérer des barres de mesure invisibles là où vous souhaitez positionner
1035 un saut de ligne. Consultez le chapitre @ruser{Barres de mesure} pour
1039 @node Apparition d'une portée supplémentaire
1040 @unnumberedsubsec Apparition d'une portée supplémentaire
1041 @translationof An extra staff appears
1043 Lorsque les contextes ne sont pas créés explicitement par la commande
1044 @code{\new}, ils le seront si la commande à exécuter n'est pas censée
1045 s'appliquer au contexte en cours. Pour des partitions simples, le fait
1046 que les contextes soient automatiquement créés rend bien des services,
1047 et c'est d'ailleurs le cas pour la majorité des exemples contenus dans
1048 les manuels de LilyPond. Cependant, la création implicite d'un contexte
1049 peut aboutir à l'apparition d'une portée @qq{parasite}. On s'attend par
1050 exemple, en lisant le code qui suit, à ce que toutes les têtes de note
1051 soient en rouge, alors que le résultat nous présente deux portées et que
1052 les notes, placées sur la portée inférieure, restent en noir.
1054 @lilypond[quote,verbatim,relative=2]
1055 \override Staff.NoteHead.color = #red
1059 Étant donné qu'aucun contexte @code{Staff} n'existe lorsque la
1060 dérogation est introduite, LilyPond le crée implicitement pour lui
1061 appliquer la directive considérée. Survient alors la commande
1062 @code{\new Staff} qui, à son tour, crée une nouvelle portée pour
1063 contenir les notes qui suivent. Voici la syntaxe correcte pour obtenir
1064 ces notes en rouge :
1066 @lilypond[quote,verbatim,relative=2]
1068 \override Staff.NoteHead.color = #red
1073 Autre exemple : la présence d'une commande @code{\relative} à
1074 l'intérieur d'une section @code{\repeat} générera obligatoirement une
1075 portée intempestive. Cela tient au fait que la commande @code{\repeat}
1076 va créer deux blocs @code{\relative} qui, chacun à leur tour, créeront
1077 implicitement un bloc @code{Staff} assorti d'un bloc @code{Voice}.
1079 @lilypond[quote,verbatim]
1081 \relative c' { c4 d e f }
1085 La manière adéquate de procéder consiste à inverser les commandes
1086 @code{\repeat} et @code{\relative}, comme ceci :
1088 @lilypond[quote,verbatim]
1091 \relative c' { c4 d e f }
1097 @node Message d'erreur Unbound variable %
1098 @unnumberedsubsec Message d'erreur @code{Unbound variable %}
1099 @translationof Error message Unbound variable %
1101 Ce message d'erreur, qu'il apparaisse sur le terminal ou en fin de
1102 fichier journal, est associé à un message du type @qq{GUILE a signalé
1103 une erreur@dots{}}. Il survient à chaque fois qu'un commentaire
1104 @emph{LilyPond} est indûment placé dans une routine @emph{Scheme}.
1106 Un commentaire LilyPond est introduit par le signe pourcent (@code{%})
1107 et ne doit en aucun cas se trouver dans une routine Scheme. En Scheme,
1108 les commentaires s'introduisent par un point-virgule (@code{;}).
1111 @node Message d'erreur FT_Get_Glyph_Name
1112 @unnumberedsubsec Message d'erreur @code{FT_Get_Glyph_Name}
1113 @translationof Error message FT_Get_Glyph_Name
1115 Ce message d'erreur, qu'il apparaisse sur le terminal ou en fin de
1116 fichier journal, survient lorsqu'un fichier source contient des
1117 caractères non ASCII et qu'il n'a pas été enregistré avec un encodage
1118 UTF-8. Pour plus de détails, reportez-vous au chapitre
1119 @ruser{Caractères spéciaux}.
1122 @node staff-affinities devraient aller en ordre décroissant
1123 @unnumberedsubsec @emph{staff-affinities} devraient aller en ordre décroissant
1124 @translationof Warning staff affinities should only decrease
1126 Cet avertissement est émis lorsque la partition ne comporte pas de
1127 portée, comme par exemple une feuille de chant avec un contexte
1128 @code{ChordName} et un contexte @code{Lyrics}. Ce message disparaîtra
1129 dès lors que vous autoriserez l'un de ces contextes à se comporter comme
1130 une portée, à l'aide de l'instruction
1133 \override VerticalAxisGroup.staff-affinity = ##f
1137 que vous insérerez dès sa création. Pour plus d'information,
1138 reportez-vous à la rubrique
1139 @ruser{Espacement des lignes rattachées à des portées}.
1142 @node Message d'erreur unexpected new
1143 @unnumberedsubsec Message d'erreur unexpected @code{@bs{}new}
1144 @translationof Error message unexpected new
1146 Un bloc @code{\score} ne peut contenir qu'@strong{une seule} expression
1147 musicale. Si, par contre, il comporte plusieurs @code{\new Staff},
1148 @code{\new StaffGroup} ou autres contextes introduits par une commande
1149 @code{\new} qui ne seraient pas bornés par des accolades
1150 @code{@{ @dots{} @}} ou des doubles chevrons @code{<< @dots{} >>} comme
1155 % Invalide ! Génère l'erreur : syntax error, unexpected \new
1156 % en français : erreur de syntaxe : \new inattendu
1157 \new Staff @{ @dots{} @}
1158 \new Staff @{ @dots{} @}
1163 vous obtiendrez ce message d'erreur.
1165 Cette erreur sera évitée dès lors que toutes les instances de
1166 @code{\new} sont bornées par des accolades ou des doubles chevrons.
1168 Des accolades placeront ces clauses @code{\new} en séquence :
1170 @lilypond[quote,verbatim]
1173 \new Staff { a' a' a' a' }
1174 \new Staff { g' g' g' g' }
1180 alors que des doubles chevrons les placeront en parallèle ; autrement
1181 dit, LilyPond les traitera simultanément :
1183 @lilypond[quote,verbatim]
1186 \new Staff { a' a' a' a' }
1187 \new Staff { g' g' g' g' }