]> git.donarmstrong.com Git - lilypond.git/blob - Documentation/programmer/regression-test.tely
patch::: 1.3.8.uu1
[lilypond.git] / Documentation / programmer / regression-test.tely
1 \input texinfo @c -*-texinfo-*-   vim:tw=72
2 @setfilename regression-test.info
3 @settitle LilyPond Regression test
4
5 @c fool ls-latex
6 @ignore
7 @author Han-Wen Nienhuys and Jan Nieuwenhuizen
8 @title LilyPond Regression test
9 @end ignore
10
11 @node Top, , ,
12
13 @section Introduction
14
15 This document tries give an brief overview of LilyPond features.  When
16 the text correspond with the shown notation, we consider LilyPond
17 Officially BugFree (tm).  This document is intended for finding bugs,
18 and documenting bugfixes.
19
20 @section Notes and rests
21
22 Rests.  Note that the dot of 8th, 16th and 32nd rests rest should be
23 next to the top of the rest.  All rests except the whole rest are
24 centered on the middle staff line.  
25
26 @mudelafile{rest.fly}
27
28 Note head shapes are settable.  The stem endings should be adjusted
29 per note head.  If you want different note head styles on one stem,
30 you must create a special context called Thread.
31
32 @mudelafile{noteheadstyle.ly}
33
34 Noteheads can have dots, and ---although this is bad style in duple
35 meters--- rests can too.  Augmentation dots should never be printed on
36 a staff line, but rather be shifted vertically. They should go up, but
37 in case of multiple parts, the down stems have down shifted dots.
38 (Wanske p. 186) In case of chords, all dots should be in a column.
39 The dots go along as rests are shifted to avoid collisions.
40
41 @mudelafile{dots.fly}
42
43 Multiple measure rests do not collide with barlines and clefs.  They
44 are not expanded when you set @code{Score.skipBars}.  Although the
45 multi-measure-rest is a Spanner, minimum distances are set to keep it
46 colliding from barlines. 
47
48 @mudelafile{multi-measure-rest.ly}
49
50 If @code{Score.skipBars} is set,
51 the signs for four, two, and one measure rest are combined to
52 produce the graphical representation of rests for up to 10 bars.
53 The number of bars will be written above the sign.
54
55 @mudelafile{mm-rests2.ly}
56
57 A sharp sign after a double sharp sign, as well as a flat sign
58 after a double flat sign is automatically prepended with a
59 natural sign.
60
61 @mudelafile{double-single-acc.ly}
62
63 @section Stems
64
65 Stem tremolos (official naming?) or rolls are tremolo signs that look
66 like beam segments crossing stems.  If the stem is in a beam, the
67 tremolo must be parallel to the beam.  If the stem is invisible
68 (eg. on a whole note), the tremolo must be centered on the note.
69
70 @mudelafile{stem-tremolo.ly}
71
72 Chord tremolos look like beams, but are a kind of repeat symbol.
73 To avoid confusion, chord tremolo beams do not reach the stems, but 
74 leave a gap.  Chord tremolo beams on half notes are not ambiguous,
75 as half notes cannot appear in a regular beam, and should reach the 
76 stems.
77   
78 @mudelafile{chord-tremolo.sly}
79
80 Beams, stems and noteheads often have communication troubles, since
81 the two systems for y dimensions (1 unit = staffspace, 1 unit = 1
82 point) are mixed.
83
84 Stems, beams, ties and slurs should behave similarly, when placed
85 on the middle staff line. Of course stem-direction is down for high
86 notes, and up for low notes.
87
88 @mudelafile{stem-direction.sly}
89
90 Similarly, if @code{stem_default_neutral_direction} is set to @code{-1}.
91
92 @mudelafile{stem-direction-down.ly}
93
94 @section Scripts
95
96 The staccato dot (and all scripts with follow-into-staff set), must
97 not be on staff lines.
98
99 @mudelafile{staccato-pos.sly}
100
101 @section Grace notes
102
103 Grace notes are typeset as an encapsulated piece of music. You can
104 have beams, notes, chords, stems etc. within a @code{\grace} section.
105 Slurs that start within a grace section, but aren't ended are attached
106 to the next normal note.  Grace notes have zero duration.  If there
107 are tuplets, the grace notes won't be under the brace.  Grace notes
108 can have accidentals, but they are (currently) spaced at a fixed
109 distance.  Grace notes (of course) come before the accidentals of the
110 main note.  Grace notes can also be positioned after the main note.
111
112 @mudelafile{grace.ly}
113
114
115 @section Beams, slurs and other spanners
116
117 Beaming is generated automatically. Beams may cross bar lines. In that
118 case, line breaks are forbidden.  Yet clef and key signatures are
119 hidden just as with breakable bar lines.
120
121 @mudelafile{beaming.ly}
122
123 Beams should behave reasonably well, even under extreme circumstances.
124 Stems may be short, but noteheads should never touch the beam.
125
126 @mudelafile{beam-extreme.ly}
127
128 Beams should always reach the middle staff line, the second beam
129 counting from the note head side, should never be lower than the
130 second staff line.  This does not hold for grace note beams.
131
132 @mudelafile{beam-position.sly}
133
134 Slurs should look nice and symmetric.  The curvature may increase
135 only to avoid noteheads, and as little as possible.
136
137 @mudelafile{slur-symmetry.ly}
138 @mudelafile{slur-symmetry-1.ly}
139
140 Ties are strictly horizontal.  They are placed in between note heads.
141 The horizontal middle should not overlap with a staffline.
142
143 @mudelafile{tie.ly}
144
145 When tieing notes with accidentals across a bar boundary, the accidental
146 must not be drawn on the note in the new bar.  Instead, the next note of
147 the same pitch in this bar should always show the accidental (even if
148 it's natural).  Slurring a accidentaled note to a natural one across bar
149 boundaries should be explicit.
150
151 Pitches can be verified by printing them  with the @code{NoteNames} context.
152
153 @mudelafile{tie-accidental.ly}
154
155 Beams can be typeset over fixed distance aligned staffs, beam
156 beautification doesn't really work, but knees do. Beams should be
157 behave well, wherever the switching point is.
158
159 @mudelafile{beam-cross-staff.ly}
160
161 The same goes for slurs. They behave decently when broken across
162 linebreak.
163
164 @mudelafile{slur-cross-staff.ly}
165
166 Tuplets are indicated by a bracket with a number.  There should be no
167 bracket if there is one beam that matches  the length of the tuplet.
168 The bracket does not interfere with the stafflines, and the number is
169 centered in the gap in the bracket.
170
171 @mudelafile{tup.ly}
172
173 @section Repeats
174
175 LilyPond has three modes for repeats: folded, unfolded and
176 semi-unfolded.  Unfolded repeats are fully written out. Semi unfolded
177 repeats have the body written and all alternatives sequentially.
178 Folded repeats have the body written and all alternatives
179 simultaneously.  If the number of alternatives is larger than the
180 repeat count, the excess alternatives are ignored.  If the number of
181 alternatives is smaller, the first alternative is multiplied to get to
182 the number of repeats.
183
184 Unfolded behavior:
185
186 @mudelafile{repeat-unfold.ly}
187
188 Volta (Semi folded) behavior.  Voltas can start on non-barline moments.
189 If they don't barlines should still be shown.
190
191 @mudelafile{repeat-volta.ly}
192
193 Folded.  This doesn't make sense without alternatives, but it works.
194
195 @mudelafile{repeat-fold.ly}
196
197 @section Lyrics
198
199 Lyrics can be set to a melody automatically.  Excess lyrics will be
200 dumped.  Lyrics will not be set over rests.  You can have melismata
201 either by setting a property melismaBusy, or by setting
202 automaticMelismas (which will set melismas during slurs and ties).  If
203 you want a different order than first Music, then Lyrics, you must
204 precook a chord of staffs/lyrics and label those.  Of course
205 @code{\rhythm} ignores any other rhythms in the piece.  Hyphens and
206 extenders do not assume anything about lyric lengths, so they continue
207 to work.
208
209 @mudelafile{lyric-combine.ly}
210
211 @section Multiple notes
212
213 Rests should not collide with beams, stems and noteheads.  Rests may
214 be under beams.  Rests should be move by integral number of spaces
215 inside the staff, and by half spaces outside.  Notice that the half
216 and whole rests just outside the staff get ledger lines in different
217 cases.
218
219 @mudelafile{rest-collision.ly}
220
221 Normal collisions. We have support for polyphony, where the
222 middle voices are horizontally shifted.
223
224 @mudelafile{collisions.ly}
225
226 The number of stafflines of a staff can be set with the property
227 numberOfStaffLines.  Ledger lines both on note heads and rests are
228 adjusted.  Barlines also are adjusted.
229
230
231 @mudelafile{number-staff-lines.fly}
232
233 @section Spacing
234
235 In a limited number of cases, LilyPond corrects for optical spacing
236 effects.  In this example, space for opposite pointed stems is adjusted
237
238 @mudelafile{stem-spacing.sly}
239
240 If there are accidentals in the music, we add space, but the space
241 between note and accidentals is less than between the notes with the
242 same value.  Clef changes also get extra space, but not as much as
243 barlines.
244
245
246 Even if a line is very tightly spaced, there will still be room
247 between prefatory matter and the following notes.  The space after the
248 prefatory is very rigid.  In contrast, the space before the barline
249 must stretch like the space within the measure.
250
251 Tight:
252
253 @mudelafile{spacing-tight.ly}
254
255 Natural:
256
257 @mudelafile{spacing-natural.ly}
258
259 Loose:
260
261 @mudelafile{spacing-loose.ly}
262
263 Adding a @code{Bar_engraver} to the LyricsVoice context makes sure that
264 lyrics don't collide with barlines.
265
266 @mudelafile{lyrics-bar.ly}
267
268 @section Global stuff
269
270 Breaks can be encouraged and discouraged using @code{\break} and
271 @code{\nobreak}.  They are abbrevs for @code{\penalty} commands.
272
273 @mudelafile{break.ly}
274
275
276 Markings that are attached to (invisible) barlines are 
277 delicate: the are attached to the rest of the score without the score
278 knowing it.  Consequently, they fall over  often.
279
280 @mudelafile{bar-scripts.ly}
281
282 Staff margins are also markings attached to barlines.  They should be
283 left of the staff, and be centered vertically wrt the staff.  They may
284 be on normal staffs, but also on compound staffs, like the PianoStaff
285
286 @mudelafile{staff-margin.ly}
287
288 Breathing signs, also used for phrasing, do normally not influence
289 global spacing -- only if space gets tight, notes are shifted to make
290 room for the breathing sign. Breathing signs break beams running
291 through their voice. In the following example, the notes in the first
292 two measures all have the same distance from each other:
293
294 @mudelafile{breathing-sign.ly}
295
296 Fonts are  available in a default set of sizes: 11, 13, 16, 20, 23 and
297 26pt staffheight.  Sizes of the text fonts and symbol fonts are made
298 to match the staff dimensions.    
299
300 @mudelafile[nofly]{size11.ly}
301
302 @mudelafile[nofly]{size13.ly}
303
304 @mudelafile[nofly]{size16.ly}
305
306 @mudelafile[nofly]{size20.ly}
307
308 @mudelafile[nofly]{size23.ly}
309
310 @mudelafile[nofly]{size26.ly}
311
312
313 @section Clefs and Time Signatures
314
315 The transparent clef should not occupy any space and with style
316 @code{fullSizeChanges}, the changing clef should be typeset in full
317 size. For octaviated clefs, the ``8'' should appear closely above or
318 below the clef respectively.  The ``8'' is processed in a convoluted
319 way, so this is fragile as well.
320
321 @mudelafile{clefs.ly}
322
323 @ignore
324 @c the input file is too long and does not test for specific bugs
325 By default, time signatures are written with two numbers. With style
326 ``C'', 4/4 and 2/2 are written with their corresponding symbols and
327 with style ``old'', 2/2, 3/2, 2/4, 3/4, 4/4, 6/4, 9/4, 4/8, 6/8 and
328 9/8 are typeset with symbols, all other signatures retain the default
329 layout. The style ``1'', gives single number signatures for all
330 signatures. 
331 %
332 \mu delafile{time.fly}
333 @end ignore
334
335 @bye