]> git.donarmstrong.com Git - lilypond.git/blob - Documentation/user/invoking.itexi
f6f8924191adb799a87c45ad1c9f20305d7d8e72
[lilypond.git] / Documentation / user / invoking.itexi
1 @c -*-texinfo-*-
2 @node Invoking LilyPond
3 @chapter Invoking LilyPond
4
5 @menu
6 * Reporting bugs::              
7 * Website::                     
8 * Invoking ly2dvi::           Titling LilyPond scores.
9 @end menu
10
11 @cindex Invoking LilyPond
12 @cindex command line options
13 @cindex options, command line
14 @cindex switches
15
16 Usage:
17
18 @example
19         lilypond [@var{option}]@dots{} @var{file}@dots{}
20 @end example
21
22
23 When invoked with a filename that has no extension, LilyPond will try
24 to add @file{.ly} as an extension first.  To have LilyPond read from
25 stdin, use a dash @code{-} for @var{file}.
26
27 When LilyPond processes @file{filename.ly} it will produce
28 @file{filename.tex} as output (or @file{filename.ps} for PostScript
29 output).  If @file{filename.ly} contains more than one @code{\score}
30 block, then LilyPond will output the rest in numbered files, starting
31 with @file{filename-1.tex}.  Several files can be specified; they will
32 each be processed independently.  @footnote{The status of GUILE is not
33 reset across invocations, so be careful not to change any default
34 settings from within Scheme .}
35
36
37 @section Command line options
38
39 The following options are supported:
40
41 @table @code
42
43 @item -e,--evaluate=@var{expr}
44 Evaluate the Scheme @var{expr} before parsing any @file{.ly} files.
45 Multiple @code{-e} options may be given, they will be evaluated
46 sequentially.  The function @code{ly-set-option} allows for access to
47 some internal variables.  Use @code{-e '(ly-option-usage')} for more
48 information.
49
50 @item -f,--format=@var{format}
51 @c
52 @c
53 Output format for sheet music. Choices are @code{tex} (for @TeX{}
54 output, to be processed with plain @TeX{}, or through ly2dvi),
55 @code{pdftex} for PDF@TeX{} input, @code{ps} (for PostScript),
56 @code{scm} (for a Scheme dump), @code{sk} (for Sketch) and @code{as}
57 (for ASCII-art).
58
59 @strong{This option is only for developers}. Only the @TeX{} output of
60 these is usable for real work. More information can be found at
61 @uref{http://lilypond.org/wiki?OutputFormats}.
62
63
64 @cindex output format, setting
65 @cindex Sketch output
66 @cindex ASCII-art output
67 @cindex PDFTeX output
68 @cindex PostScript output
69 @cindex Scheme dump
70
71 @item -h,--help
72 Show a summary of usage.
73 @item --include, -I=@var{directory}
74 Add @var{directory} to the search path for input files.
75 @cindex file searching
76 @cindex search path
77 @item -i,--init=@var{file}
78 Set init file to @var{file} (default: @file{init.ly}).
79 @item -m,--no-paper
80 @cindex MIDI
81 Disable @TeX{} output. If you have a @code{\midi} definition midi output
82 will be generated.
83 @item -M,--dependencies
84 Output rules to be included in Makefile.
85 @item -o,--output=@var{FILE}
86 Set the default output file to @var{FILE}.
87
88 @ignore
89 @item -s,--safe
90 Disallow untrusted @code{\include} directives, in-line
91 Scheme evaluation, backslashes in @TeX{}, code.
92
93 @strong{WARNING}: the @code{--safe} option has not been reviewed for a
94 long time. Do not rely on it for automatic invocation (e.g. over the
95 web). Volunteers are welcome to do a new audit.
96 @end ignore
97
98 @item -v,--version
99 Show version information 
100 @item -V,--verbose
101 Be verbose: show full paths of all  files read, and give timing
102 information.
103
104 @item -w,--warranty
105 Show the warranty with which GNU LilyPond comes. (It comes with 
106 @strong{NO WARRANTY}!)
107 @end table
108
109 @section Environment variables
110
111
112 For processing both the @TeX{} and the PostScript output, you must
113 have appropriate environment variables set.  Scripts to do this are
114 included in @file{buildscripts/out/lilypond-profile} (for sh shells)
115 and @file{buildscripts/out/lilypond-login} (for C-shells), and should
116 normally be sourced as part of your login process. If these scripts
117 are not run from the system wide login process, then you must run it
118 yourself.
119
120 @cindex installing LilyPond
121
122 If you use sh, bash, or a similar shell, then add the following to
123 your @file{.profile}
124 @example
125         . lilypond-profile
126 @end example
127
128 If you use csh, tcsh or a similar shell, then add the following to
129 your @file{~/.login}
130 @example
131         source lilypond-login
132 @end example
133
134 These scripts set the following variables
135 @table @code
136 @item TEXMF
137  To make sure that @TeX{} and lilypond find data files (among
138 others @file{.tex}, @file{.mf} and @file{.tfm}),
139 you have to set @code{TEXMF} to point to the lilypond data
140 file tree. A typical setting would be
141 @example
142 @{/usr/share/lilypond/1.6.0,@{!!/usr/share/texmf@}@}
143 @end example
144
145
146 @item GS_LIB
147 For processing PostScript output (obtained with
148 @code{-f ps}) with Ghostscript you have to set @code{GS_LIB} to
149 point to the directory containing LilyPond PS files.
150
151 @item GS_FONTPATH
152 For processing PostScript output (obtained with
153 @code{-f ps}) with Ghostscript you have to set @code{GS_FONTPATH} to
154 point to the directory containing LilyPond PFA files.
155
156 When you print direct PS output, remember to send the PFA files to the
157 printer as well.
158 @end table
159
160
161 @cindex ghostscript
162 @cindex PostScript
163 @cindex GS_FONTPATH
164 @cindex GS_LIB
165 @cindex TEXMF
166 @cindex printing postscript
167
168 The LilyPond binary itself recognizes the following environment variables
169 @table @code
170 @item LILYPONDPREFIX
171 This specifies a directory where locale messages and
172 data files will be looked up by default. The directory should contain
173 subdirectories called @file{ly/}, @file{ps/}, @file{tex/}, etc.
174
175 @item LANG
176 This selects the language for the warning messages of LilyPond.
177 @end table
178
179 @cindex LANG
180 @cindex LILYPONDPREFIX
181
182
183
184 @cindex bugs
185 @cindex reporting bugs
186
187 @node Reporting bugs
188 @section Reporting bugs
189
190 Since there is no finder's fee which doubles every year, there is no
191 need to wait for the prize money to grow. So send a bug report today!
192
193 LilyPond development moves quickly, so if you have a problem, it is
194 wise to check if it has been fixed in a newer release.  If you think
195 you found a bug, please send in a bugreport.  When you send us a
196 bugreport, we have to diagnose the problem and if possible, duplicate
197 it.  To make this possible, it is important that you include the
198 following information in your report:
199
200 @itemize @bullet
201
202 @item A sample input which causes the error.  Please have mercy on the
203 developers, send a @emph{small} sample file.
204
205 @item The version number of lilypond.
206
207 @item A description of the platform you use (i.e., operating system,
208 system libraries, whether you downloaded a binary release)
209
210 @item If necessary, send a description of the bug itself.  If you
211 include output a ly2dvi run, please use @code{--verbose} option of
212 ly2dvi.
213
214 @end itemize
215
216 You can send the report to @email{bug-lilypond@@gnu.org}. This is a
217 mailinglist, but you don't have to be subscribed to it to post.
218
219 @node Website
220 @section Website
221
222 If you are reading this manual in print, it is possible that the
223 website contains updates to the manual. You can find the lilypond
224 website at @uref{http://www.lilypond.org/}.
225
226
227 @node Invoking ly2dvi
228 @section Invoking ly2dvi
229
230 Nicely titled output is created through a separate program:
231 @file{ly2dvi} is a script that uses LilyPond and La@TeX{} to create a
232 nicely titled piece of sheet music, in DVI format or PostScript.
233
234 @example
235         ly2dvi [@var{option}]@dots{} @var{file}@dots{}
236 @end example
237
238 To have ly2dvi read from stdin, use a dash @code{-} for @var{file}.
239
240 Ly2dvi supports the following options:
241
242 @table @code
243 @item -k,--keep
244     Keep the temporary directory including LilyPond and ly2dvi output
245 files. The temporary directory is created in the current directory as @code{ly2dvi.dir}.
246 @item -d,--dependencies
247     Write makefile dependencies for every input file.
248 @item -h,--help
249     Print usage help.
250 @item -I,--include=@var{dir}
251     Add @var{dir} to LilyPond's include path.
252 @item -m,--no-paper
253     Produce MIDI output only.
254 @item --no-lily
255     Do not run LilyPond; useful for debugging ly2dvi.
256 @item -o,--output=@var{file}
257     Generate output to @var{file}.  The extension of @var{file} is ignored.
258 @item -P,--postscript
259     Also generate PostScript output, using dvips.  The postscript uses
260 the standard @TeX{} bitmap fonts for your printer.
261 @item -p,--pdf
262     Also generate Portable Document Format (PDF).  This option will
263 generate a PS file using scalable fonts, and will run the PS file
264 through @code{ps2pdf} producing a PDF file.
265
266 @cindex PDF
267 @cindex Scalable fonts
268     
269     If you use lilypond-book or your own wrapper files, don't use
270 @code{\usepackage[[T1]@{fontenc@}} in the file header but don't forget
271 @code{\usepackage[latin1]@{inputenc@}} if you use any other
272 non-anglosaxian characters.
273
274     @item --preview
275     Also generate a picture of the first system of the score.
276 @item -s,--set=@var{key}=@var{val}
277     Add @var{key}= @var{val} to the settings, overriding those specified
278 in the files. Possible keys: @code{language}, @code{latexheaders},
279 @code{latexpackages}, @code{latexoptions}, @code{papersize},
280 @code{pagenumber}, @code{linewidth}, @code{orientation},
281 @code{textheight}.
282 @item -v,--version
283 Show version information 
284 @item -V,--verbose
285 Be verbose
286 @item -w,--warranty
287 Show the warranty with which GNU LilyPond comes. (It comes with 
288 @strong{NO WARRANTY}!)
289 @end table
290
291 @subsection Titling layout
292
293 Ly2dvi extracts the following header fields from the LY files to
294 generate titling:
295
296 @table @code
297 @item title
298     The title of the music. Centered on top of the first page.
299 @item subtitle
300     Subtitle, centered below the title.
301 @item poet
302     Name of the poet, left flushed below the subtitle.
303 @item composer
304     Name of the composer, right flushed below the subtitle.
305 @item meter
306     Meter string, left flushed below the poet.
307 @item opus
308     Name of the opus, right flushed below the composer.
309 @item arranger
310     Name of the arranger, right flushed below the opus.
311 @item instrument
312     Name of the instrument, centered below the arranger
313 @item piece
314     Name of the piece, left flushed below the instrument
315 @item head
316     A text to print in the header of all pages. It is not called
317 @code{header}, because @code{\header} is a reserved word in LilyPond.
318 @item copyright
319     A text to print in the footer of the first page. Default is to 
320     print the standard footer also on the first page.
321 @item footer
322     A text to print in the footer of all but the last page.
323 @item tagline
324     Line to print at the bottom of last page. The default text is ``Lily
325 was here, @var{version-number}''.
326 @end table
327
328
329 @cindex header
330 @cindex footer
331 @cindex page layout
332 @cindex titles
333
334
335
336 @subsection Additional parameters
337
338 Ly2dvi responds to several parameters specified in a @code{\paper}
339 section of the LilyPond file. They can be overridden by supplying a
340 @code{--set} command line option.
341
342 @table @code
343 @item language
344     Specify La@TeX{} language: the @code{babel} package will be
345 included.  Default: unset.
346
347         Read from the @code{\header} block.
348
349 @item latexheaders
350     Specify additional La@TeX{} headers file.
351
352         Normally read from the @code{\header} block. Default value: empty
353
354 @item latexpackages
355     Specify additional La@TeX{} packages file. This works cumulative,
356 so you can add multiple packages using multiple @code{-s=latexpackages} options.
357        Normally read from the @code{\header} block. Default value:
358 @code{geometry}.
359
360 @item latexoptions
361     Specify additional options for the La@TeX{}
362 @code{\documentclass}. You can put any valid value here. This was
363 designed to allow ly2dvi to produce output for double-sided paper,
364 with balanced margins and pagenumbers on alternating sides. To achieve
365 this specify @code{twoside}
366
367 @item orientation
368     Set orientation. Choices are @code{portrait} or @code{landscape}. Is
369 read from the @code{\paper} block, if set.
370         
371 @item textheight
372     The vertical extension of the music on the page. It is normally 
373     calculated automatically, based on the paper size.
374
375 @item linewidth
376         The music line width. It is normally read from the @code{\paper}
377 block.
378
379 @item papersize
380    The paper size (as a name, e.g. @code{a4}). It is normally read from
381 the @code{\paper} block.
382
383 @item pagenumber
384    If set to @code{no}, no page numbers will be printed.  If set to a
385 positive integer, start with this value as the first page number.
386
387   
388   @item fontenc
389      The font encoding, should be set identical to the @code{font-encoding}
390      property in the score.
391 @end table
392
393 @subsection Environment variables
394
395 @table @code
396 @item LANG
397 selects the language for the warning messages of Ly2dvi and LilyPond.
398
399 @item GUILE_MAX_SEGMENT_SIZE
400 is an option for GUILE, the scheme interpreter; it sets the size of
401 the chunks of memory allocated by GUILE.  By increasing this from its
402 default 8388608, the performance of LilyPond on large scores is
403 slightly improved.
404
405
406 @end table
407
408