LilyPond Regression Tests


Introduction

This document presents proofs for LilyPond dev. When the text corresponds with the shown notation, we consider LilyPond Officially BugFree (tm). This document is intended for finding bugs and for documenting bugfixes.

In the web version of this document, you can click on the file name or figure for each example to see the corresponding input file.

TODO: order of tests (file names!), test only one feature per test. Smaller and neater tests.


Regression test cases

to-staff-space produces identical output for different settings of set-global-staff-size and layout-set-staff-size.

For the tests we use \abs-vspace, which in turn calls to-staff-space.

absolute-dimensions-size10-layout30.ly

[image of music]

to-staff-space produces identical output for different settings of set-global-staff-size and layout-set-staff-size.

For the tests we use \abs-vspace, which in turn calls to-staff-space.

absolute-dimensions-size30-layout10.ly

[image of music]

Natural signs don’t displace accents.

accidental-accent.ly

[image of music]

Accidentals are available in different ancient styles, which all are collected here.

accidental-ancient.ly

[image of music]

When a tie is broken, the spacing engine must consider the accidental after the line break. The second and third lines should have the same note spacing.

accidental-broken-tie-spacing.ly

[image of music]

Test if cautionary accidentals have the same horizontal spacing correction as regular accidentals.

accidental-cautionary-horizontal-spacing.ly

[image of music]

Test if Scripts are placed over notes with accidentals the same way as over notes with cautionary accidentals.

accidental-cautionary-script-placement.ly

[image of music]

Cautionary accidentals may be indicated using either parentheses (default) or smaller accidentals.

accidental-cautionary.ly

[image of music]

Accidentals are invalidated at clef changes.

accidental-clef-change.ly

[image of music]

accidentals avoid stems of other notes too.

accidental-collision.ly

[image of music]

Several automatic accidental rules aim to reproduce contemporary music notation practices:

  • 'dodecaphonic style prints accidentals on every note (including naturals)
  • 'neo-modern style prints accidentals on every note (not including naturals), except when a note is immediately repeated
  • 'neo-modern-cautionary style acts like neo-modern, adding cautionary parentheses around accidentals.
  • 'teaching prints accidentals normally, but adds cautionary accidentals when an accidental is already included in the key signature.

Both scores should show the same accidentals.

accidental-contemporary.ly

[image of music]

If two forced accidentals happen at the same time, only one sharp sign is printed.

accidental-double.ly

[image of music]

Horizontal Fingering grobs should not collide with accidentals.

accidental-fingering-collision.ly

[image of music]

Accidentals can be forced with ! and ? even if the notes are tied. Cautionary accidentals applied to tied notes after a bar line are valid for the whole measure.

accidental-forced-tie.ly

[image of music]

By setting accidentalGrouping to 'voice, LilyPond will horizontally stagger the accidentals of octaves in different voices as seen in this test’s E-sharp.

accidental-grouping.ly

[image of music]

Ledger lines are shortened when there are accidentals. This happens only for the single ledger line close to the note head, and only if the accidental is horizontally close to the head.

accidental-ledger.ly

[image of music]

This shows how accidentals in different octaves are handled. The note names are also automatically printed but the octavation has been dropped out.

accidental-octave.ly

[image of music]

In piano accidental style, notes in both staves influence each other. In this example, each note should have an accidental.

accidental-piano.ly

[image of music]

Accidental padding works for all accidentals, including those modifying the same pitch.

accidental-placement-padding.ly

[image of music]

When two (or more) accidentals modify the same pitch, they are printed adjacent to one another unless they represent the same alteration, in which case they are printed in exactly the same position as one another. In either case, collisions with accidentals of different pitches are correctly computed.

accidental-placement-samepitch.ly

[image of music]

Accidentals are placed as closely as possible. Accidentals in corresponding octaves are aligned. The top accidental should be nearest to the chord. The flats in a sixth should be staggered.

accidental-placement.ly

[image of music]

Quarter tone notation is supported, including threequarters flat.

accidental-quarter.ly

[image of music]

A sharp sign after a double sharp sign, as well as a flat sign after a double flat sign is automatically prepended with a natural sign.

accidental-single-double.ly

[image of music]

Test all available accidental styles.

accidental-styles.ly

[image of music]

setting the suggestAccidentals will print accidentals vertically relative to the note. This is useful for denoting Musica Ficta.

accidental-suggestions.ly

[image of music]

The second and third notes should not get accidentals, because they are tied to a note. However, an accidental is present if the line is broken at the tie, which happens for the G sharp.

The presence of an accidental after a broken tie can be overridden.

accidental-tie.ly

[image of music]

Space is allowed for the actual size of accidentals on tied notes.

accidental-unbroken-tie-spacing.ly

[image of music]

This shows how modern cross voice auto cautionary accidentals are handled. The first two fisses get accidentals because they belong to different voices. The first f gets cautionary natural because of previous measure. The last f gets cautionary natural because fis was only in the other voice.

accidental-voice.ly

[image of music]

Accidentals work: the second note does not get a sharp. The third and fourth show forced and cautionary accidentals.

accidental.ly

[image of music]

Accordion register symbols are available in the (lily accreg) module as \markup and as standalone music events.

accreg.ly

[image of music]

\add-grace-property can be used at various context levels in order to override grace properties. Overrides in different parallel contexts are independent.

add-grace-property.ly

[image of music]

add-stem-support can be removed or implemented only for beamed notes.

add-stem-support.ly

[image of music]

This is a test of combining post-events with various constructs. Problems are reported on the stderr of this run; there are no images produced.

added-post-event-test.ly

[image of music]

\addlyrics should be able to attach itself to named and unnamed Voice constructs. For all tests where this succeeds, the noteheads will be red.

addlyrics-existing-context.ly

[image of music]

\addlyrics may get used on a Staff context and will then consider all note events created below it for synchronization.

addlyrics-to-staff-context.ly

[image of music]

Delayed post-events and other types of music can be created with \after and \afterGrace.

after.ly

[image of music]

A warning is emitted when the context specified in alignAboveContext or alignBelowContext does not exist, such as when the context having the alignAboveContext or alignBelowContext property is created before the context that this property refers to.

alignment-order-unfound-context.ly

[image of music]

Newly created contexts can be inserted anywhere in the vertical alignment.

alignment-order.ly

[image of music]

Alignments may be changed per system by setting alignment-distances in the line-break-system-details property

alignment-vertical-manual-setting.ly

[image of music]

By default, certain staff contexts for ancient music do not forbid line breaks between bar lines. The output should have a break at a point without a bar line.

allow-break-ancient.ly

[image of music]

The \allowBreak command inserts a break point regardless of bar lines, unbreakable spanners, etc. This test should have a break in the middle of a measure.

allow-break.ly

[image of music]

The command \alterBroken may be used to override the pieces of a broken spanner independently. The following example demonstrates its usage with a variety of data types.

alter-broken.ly

[image of music]

Alternative notation systems using accidentals different from the Western ones set them systematically, for standalone markups and all grobs that print accidentals.

This include file provides a function to draw many accidental in different contexts. It is used by various tests.

alteration-glyphs.ly

[image of music]

This case places \alternative within the body of a \repeat segno, with the alternatives at the end of the repeated section, but with volta numbers out of order. Alternative bar numbering is enabled.

The alternatives are notated with brackets rather than coda signs. Repetition is notated with a segno and simplified D.S. instructions that have no return counts or section labels. Alternative bar numbers appear.

alternative-end-segno.ly

[image of music]

This case places \alternative within the body of a \repeat volta, with the alternatives at the end of the repeated section. The alternatives receive volta brackets, bar numbers, and ending repeat bar lines. They unfold as expected.

alternative-end.ly

[image of music]

This case places \alternative within the body of a \repeat segno, neither at the start nor the end of the section. The alternatives receive volta brackets and bar numbers, but no coda marks or repeat bar lines. They unfold as expected.

alternative-middle-segno.ly

[image of music]

This case places \alternative within the body of a \repeat volta, neither at the start nor the end of the section. The alternatives receive volta brackets and bar numbers, but no repeat bar lines. They unfold as expected.

alternative-middle.ly

[image of music]

A whole-measure rest starting in a volta alternative is placed correctly.

alternative-mmrest.ly

[image of music]

This case nests one \alternative within another at the tail end of a \repeat segno. Alternative bar numbering is enabled.

The outer alternative receives a coda mark, no volta bracket, and normal bar numbering.

The inner alternative receives a volta bracket. Alternative bar numbering is used because it is the outermost volta bracket. The bracket communicates the return count, so the return count is omitted from the D.C. instruction to avoid redundancy.

The music unfolds to ABC ABC AD.

alternative-nest-end-end-segno1.ly

[image of music]

This case nests one \alternative within another at the tail end of a \repeat segno. Alternative bar numbering is enabled.

The outer alternative receives a coda mark, no volta bracket, and normal bar numbering.

The inner alternative receives volta brackets. Alternative bar numbering is used because they are the outermost volta brackets.

The music unfolds to ABC ABD AE.

alternative-nest-end-end-segno2.ly

[image of music]

This case nests one \alternative within another at the tail end of a \repeat volta. Alternative bar numbering is enabled.

The outer alternative receives a volta bracket and alternative bar numbering.

The inner alternative receives volta brackets and does not interrupt the bar numbering of the outer alternative.

The music unfolds to AB ACDE ACDF.

alternative-nest-end-end.ly

[image of music]

\alternative music can be assigned to a variable and used in multiple places, even with different repeat counts.

alternative-reuse.ly

[image of music]

This case places \alternative within the body of a \repeat segno, with the alternatives starting at the start of the repeated section and ending before the end of the section. The alternatives receive volta brackets and bar numbers, but no coda marks or ending repeat bar lines. They unfold as expected.

alternative-start-segno.ly

[image of music]

This case places \alternative within the body of a \repeat volta, with the alternatives starting at the start of the repeated section and ending before the end of the section. The alternatives receive volta brackets and bar numbers, but no ending repeat bar lines. They unfold as expected.

alternative-start.ly

[image of music]

A score with \alternative outside of \repeat is processed gracefully. The visual output is not important.

alternative-top-level.ly

[image of music]

Alternative music in a variable does not automatically attach to preceding \repeat, but \alternative attaches it.

alternative-trailing-var.ly

[image of music]

Ambitus for pieces beginning with \cueDuringWithClef.

Cues are often used at or near the beginning of a piece. Furthermore, a cue is frequently in a different clef, so the \cueDuringWithClef command is handy. Using this command at the beginning of a piece should leave the ambitus displayed based on the main clef.

An Ambitus_engraver should ignore notes in CueVoice contexts.

ambitus-cue.ly

[image of music]

The gaps between an AmbitusLine and its note heads are set by the gap property. By default, gap is a function that reduces the gap for small intervals (e.g. a fourth), so that the line remains visible.

ambitus-gap.ly

[image of music]

Ambitus engraver should obey middleCOffset, middleCPosition, and the staffLineLayoutFunction.

All three staves should look the same.

ambitus-middleC.ly

[image of music]

A voice with \ottava shouldn’t confuse ambitus.

ambitus-ottava.ly

[image of music]

Adding ambitus to percussion contexts does not cause crashes, since the Ambitus_engraver will only acknowledge pitched note heads.

ambitus-percussion-staves.ly

[image of music]

Ambitus use actual pitch not lexicographic ordering.

ambitus-pitch-ordering.ly

[image of music]

Ambitus can be moved to various positions with correct horizontal spacing in all cases.

ambitus-position.ly

[image of music]

A voice with Ambitus_engraver that starts with a skip while another voice starts with a note does not cause a programming error.

ambitus-skip-at-start.ly

[image of music]

Ambitus accidentals (whether present or not) are ignored by the slur engravers.

ambitus-slur.ly

[image of music]

A \Voice should be able to contain both an Ambitus_engraver and a Mensural_ligature_engraver without segfaulting.

ambitus-with-ligature.ly

[image of music]

Ambitus indicate pitch ranges for voices.

Accidentals only show up if they’re not part of key signature. AmbitusNoteHead grobs also have ledger lines. The noteheads are printed in overstrike, so there’s only one visible; the accidentals are prevented from colliding.

ambitus.ly

[image of music]

Footnotes and balloons also work on system start delimiters.

annotate-system-start-delimiter.ly

[image of music]

Footnotes and balloons also work on volta brackets running to the end of the piece.

annotate-volta-spanner-end.ly

[image of music]

With \applyContext, \properties can be modified procedurally. Applications include: checking bar numbers, smart octavation.

This example prints a bar-number during processing on stdout.

apply-context.ly

[image of music]

The \applyOutput expression is the most flexible way to tune properties for individual grobs.

Here, the layout of a note head is changed depending on its vertical position.

apply-output.ly

[image of music]

Alternative notation systems using accidentals different from the Western ones set them systematically, for standalone markups and all grobs that print accidentals.

This include file provides a function to draw many accidental in different contexts. It is used by various tests.

arabic-accidental-glyphs.ly

[image of music]

A square bracket on the left indicates that the player should not arpeggiate the chord.

arpeggio-bracket.ly

[image of music]

Arpeggio stays clear of accidentals and flipped note heads.

arpeggio-collision.ly

[image of music]

Arpeggios do not overshoot the highest note head. The first chord in this example simulates overshoot using 'positions for comparison with the correct behavior.

Exceptions are intervals smaller than a third; we ensure to have at least two wiggles (or a wiggle plus an arrow head).

arpeggio-no-overshoot.ly

[image of music]

Arpeggios still work in the absence of a staff-symbol.

arpeggio-no-staff-symbol.ly

[image of music]

There is a variant of the arpeggio sign that uses a ‘vertical slur’ instead of the wiggle.

arpeggio-parenthesis.ly

[image of music]

Cross-staff or -voice arpeggios which include single note heads as anchors do not collide with previous note heads or prefatory material.

arpeggio-span-collision.ly

[image of music]

Span arpeggios that are not cross-staff do not have horizontal spacing problems.

arpeggio-span-one-staff-collision.ly

[image of music]

Span arpeggios within one staff also work

arpeggio-span-one-staff.ly

[image of music]

Arpeggios are supported, both cross-staff and broken single staff.

arpeggio.ly

[image of music]

The snappizzicato articulation adds a snappizzicato sign to the note.

articulation-snappizzicato.ly

[image of music]

Augmentum dots are accounted for in horizontal spacing.

augmentum.ly

[image of music]

Automatic beams do not cross bar lines.

auto-beam-bar.ly

[image of music]

Autobeamer remembers subdivideBeams and other beaming pattern related functions at the start of an autobeam.

auto-beam-beaming-override.ly

[image of music]

Automatic beams are ended early if a breathing sign is encountered.

auto-beam-breathe.ly

[image of music]

beamExceptions is used to modify the automatic beaming for certain durations; the expected grouping is given after the note duration.

auto-beam-exceptions.ly

[image of music]

The autobeamer may be switched off for a single note with \noBeam.

auto-beam-no-beam.ly

[image of music]

Beamable notes do not extend a staff. The staff with the note should end immediately after the note.

auto-beam-ossia.ly

[image of music]

Grace notes at the start of a partial measure do not break autobeaming.

auto-beam-partial-grace.ly

[image of music]

Autobeaming works properly in partial measures.

auto-beam-partial.ly

[image of music]

In 4/4 time, the first and second and third and fourth beats should be beamed together if only eighth notes are involved. If any shorter notes are included, each beat should be beamed separately.

auto-beam-recheck.ly

[image of music]

Automatic beaming is also done on tuplets.

auto-beam-triplet.ly

[image of music]

Tuplet-spanner should not put (visible) brackets on beams even if they’re auto generated.

auto-beam-tuplets.ly

[image of music]

Bar lines are disabled for this test to prove that certain beaming decisions do not depend on them. The notes should be beamed in groups of 2, 6, 6, and 2.

auto-beam-without-bar-lines.ly

[image of music]

Beams are placed automatically; the last measure should have a single beam.

auto-beam.ly

[image of music]

\autoBreaksOff disables automatic line breaks and page breaks. \autoBreaksOn reenables both of them.

auto-breaks.ly

[image of music]

Auto change piano staff switches voices between up and down staves automatically; rests are switched along with the coming note. When central C is reached, staff is not yet switched (by default).

auto-change.ly

[image of music]

\autoLineBreaksOff can be used to turn off automatic line breaking. \autoLineBreaksOn reenables it.

auto-line-breaks.ly

[image of music]

\autoPageBreaksOff turns off automatic page breaking; \autoPageBreaksOn reenables it.

auto-page-breaks.ly

[image of music]

Beaming in 3/4 time has special treatment. By default six eighth notes are beamed in one. Beams that would imply 6/8 time may be avoided with beamHalfMeasure = ##f. When the beaming is changed, beams should start at the beginning of the measure.

autobeam-3-4-rules.ly

[image of music]

\noBeam should terminate an autobeam, even if it’s not a recommended place for stopping a beam. In this example, the first three eighth notes should be beamed.

autobeam-nobeam.ly

[image of music]

Default autobeam settings have been set for a number of time signatures. Each score shows the desired beaming

autobeam-show-defaults.ly

[image of music]

Autobeam rechecking works properly with tuplets. In the example, the first beat should be beamed completely together.

autobeam-tuplet-recheck.ly

[image of music]

This is a regression test for an \autochange scenario reported in issue 6575. The stem of the C should point down.

autochange-after-rest.ly

[image of music]

Other clefs for the autoChanger may be set. This works for implicitly created staves only. The first example should turn at b with soprano-clef in the upper Staff. The second example should turn at d’ with alto-clef in the upper and tenor-clef in the lower Staff.

autochange-clefs.ly

[image of music]

Grace notes are placed on the appropriate staff.

autochange-inside-grace.ly

[image of music]

Music functions that scale durations also scale \autoChange decisions. The four measures should have identical notes.

autochange-inside-scale-durations.ly

[image of music]

\keepWithTag works with \autoChange.

autochange-keep-with-tag.ly

[image of music]

\autoChange needs to be given pitches in their final octaves, so if \relative is used it must be applied inside \autoChange. The pitches in \autoChange are unaffected by an outer \relative, so that the printed output shows the pitches that \autoChange used.

The expected output of this test is three identical measures.

autochange-relative.ly

[image of music]

Other turning points for the autoChanger are possible.

autochange-turning-pitch.ly

[image of music]

Grace notes are placed on the appropriate staff.

autochange-with-grace.ly

[image of music]

The bottom-level contexts in polyphony shorthand are allocated a context id in order of creation, starting with "1". This snippet will fail to compile if either voice has an invalid context-id string.

automatic-polyphony-context-id.ly

[image of music]

In a DrumStaff, automatic polyphony can be used without explicitly initializing separate voices.

automatic-polyphony-drumstaff.ly

[image of music]

In a TabStaff, automatic polyphony can be used without explicitly initializing separate voices.

automatic-polyphony-tabstaff.ly

[image of music]

Exercise all output functions

backend-exercise.ly

[image of music]

The Bärenreiter edition of the Cello Suites is the most beautifully typeset piece of music in our collection of music (we both own one. It is also lovely on French Horn). This piece does not include articulation, but it does follows the same beaming and linebreaking as the printed edition. This is done in order to benchmark the quality of the LilyPond output.

As of lilypond 1.5.42, the spacing and beam quanting is almost identical.

There are two tweaks in this file: a line-break was forced before measure 25, we get back the linebreaking of Bärenreiter. The stem direction is forced in measure 24. The last beam of that measure is up in Bärenreiter because of context. We don’t detect that yet.

Note that the Bärenreiter edition contains a few engraving mistakes. The second line begins with measure 6 (but prints 5). The |: half way in measure 13 has been forgotten.

baerenreiter-sarabande.ly

[image of music]

The alignment of a balloon text can be customized as well as the attachment point of the line connecting it to the frame.

balloon-attachments.ly

[image of music]

Balloons on breakable items are visible if and only if the item they annotate is visible.

balloon-breakable.ly

[image of music]

Balloons work on cross-staff grobs.

balloon-cross-staff.ly

[image of music]

Balloons work on spanners that have no pure height.

balloon-empty-pure-height.ly

[image of music]

Balloons also reserve space vertically when the Balloon_engraver is in Score context.

balloon-engraver-score-spacing.ly

[image of music]

Balloons can be attached to glissandi.

balloon-glissando.ly

[image of music]

Outside-staff positioning correctly takes balloons into account.

balloon-outside-staff.ly

[image of music]

BalloonText supports the spanner-placement property.

balloon-spanner-placement.ly

[image of music]

Balloons on spanners, such as slurs, are supported.

balloon-spanner.ly

[image of music]

The thickness of balloons scales with staff size.

balloon-staff-size.ly

[image of music]

Balloons work on stem tremoli.

balloon-stem-tremolo.ly

[image of music]

Balloons work on beamed stems.

balloon-stem.ly

[image of music]

Stencils are copied before moved for Balloons instead of modified. In the test, the point-stencil in the second system should not inherit the extent from the null-markup in the first and the bar should be much shorter.

balloon-stencil.ly

[image of music]

BalloonText has configurable thickness.

balloon-thickness.ly

[image of music]

Balloons can be attached to voice followers.

balloon-voice-follower.ly

[image of music]

With balloon texts, objects in the output can be marked, with lines and explanatory text added.

balloon.ly

[image of music]

Music between \cadenzaOn and \cadenzaOff does not count toward the length of a measure; however when a cadenza begins at a measure boundary, bar checks during or immediately after the cadenza do produce warnings. This test should run with expected warnings only.

bar-check-after-cadenza-warn.ly

[image of music]

Simultaneous, valid bar checks at the end of volta-style repeat alternatives are not susceptible to false warnings. This test should run without warnings.

bar-check-parallel-alternative-ok.ly

[image of music]

The meaning of | is stored in the identifier "|".

bar-check-redefine.ly

[image of music]

A bar check between two volta-style repeat alternatives which is not aligned with respect to either one produces a warning. This test should run with expected warnings only.

bar-check-submeasure-alternative-warn.ly

[image of music]

Bar line extent can be customised and the customised value must be respected when staff symbol is changed temporarily (e.g. to simulate ledger lines of renaissance prints and manuscripts); moreover, span bars should not enter the staves.

bar-extent.ly

[image of music]

\defineBarLine accepts annotations in the end-of-line glyph name that can be used to distinguish bar lines that should close a volta bracket from those that should not. Bracket 1 should end open and bracket 2 should end closed.

bar-line-allow-volta-hook.ly

[image of music]

Test predefined bar types at the beginning, middle, and end of a line. The types in this group are intended for a caesura at a line break.

bar-line-built-in-caesura-eol.ly

[image of music]

Test predefined bar types at the beginning, middle, and end of a line. The types in this group are intended for use where one repeated section ends and another begins.

bar-line-built-in-double-repeat.ly

[image of music]

Test a spacer bar line at the beginning, middle, and end of a line.

bar-line-built-in-empty.ly

[image of music]

Test predefined bar types at the beginning, middle, and end of a line. The types in this group are intended for use where one repeated section ends, another begins, and there is an in-staff segno.

bar-line-built-in-end-repeat-segno-start-repeat.ly

[image of music]

Test predefined bar types at the beginning, middle, and end of a line. The types in this group are intended for use where a repeated section ends and there is an in-staff segno.

bar-line-built-in-end-repeat-segno.ly

[image of music]

Test predefined bar types at the beginning, middle, and end of a line. The types in this group are intended for use at the end of a repeated section.

bar-line-built-in-end-repeat.ly

[image of music]

Test predefined bar types at the beginning, middle, and end of a line. The types in this group are intended for use at the end of a section.

bar-line-built-in-end-section.ly

[image of music]

Test predefined bar types at the beginning, middle, and end of a line. The types in this group are intended for use where a repeated section begins and there are both a Fine and an in-staff segno.

bar-line-built-in-fine-segno-start-repeat.ly

[image of music]

Test predefined bar types at the beginning, middle, and end of a line. The types in this group are intended for use where there are both a Fine and an in-staff segno.

bar-line-built-in-fine-segno.ly

[image of music]

Test predefined bar types at the beginning, middle, and end of a line. The types in this group are intended for use as measure bar lines.

bar-line-built-in-measure.ly

[image of music]

Test predefined bar types at the beginning, middle, and end of a line. The types in this group are intended for use between sections.

bar-line-built-in-section.ly

[image of music]

Test predefined bar types at the beginning, middle, and end of a line. The types in this group intended for use where a repeated section starts and there is an in-staff segno.

bar-line-built-in-segno-start-repeat.ly

[image of music]

Test predefined bar types at the beginning, middle, and end of a line. The types in this group are intended for use where there is an in-staff segno.

bar-line-built-in-segno.ly

[image of music]

Test predefined bar types at the beginning, middle, and end of a line. The types in this group are intended for use at the start of a repeated section.

bar-line-built-in-start-repeat.ly

[image of music]

Test predefined bar types at the beginning, middle, and end of a line. The types in this group are intended for use at the start of a section.

bar-line-built-in-start-section.ly

[image of music]

When caesuraType is set appropriately, \caesura inserts a double bar line with priority higher than a measure bar line and lower than a section bar line.

These notes should be followed by these bar lines: D, double; E, double; F, double; G, double; A, thick.

bar-line-caesura-double.ly

[image of music]

When caesuraType is set appropriately, \caesura inserts a double bar visible only at line break, with priority less than a measure bar.

These notes should be followed by these bar lines: D, none; E, single; F, dotted; G, single; A, double; B, double.

bar-line-caesura-eol-double.ly

[image of music]

When caesuraType is set appropriately, \caesura inserts a bar line that is visible only at a line break.

These notes should be followed by these bar lines: D, none; E, single; F, double; G, single; A, single; B, single.

bar-line-caesura-eol-single.ly

[image of music]

When caesuraType is set appropriately, \caesura inserts a thick bar line that is visible only at a line break, with priority less than a measure bar.

These notes should be followed by these bar lines: D, none; E, single; F, double; G, single; A, thick; B, thick.

bar-line-caesura-eol-thick.ly

[image of music]

A user-defined empty bar glyph behaves like the built-in empty bar glyph. The horizontal space between notes should be the same in both measures.

bar-line-define-bar-glyph-empty.ly

[image of music]

New bar line glyphs can be defined in Scheme.

bar-line-define-bar-glyph.ly

[image of music]

A user-defined empty bar line with an annotation in the name behaves like the built-in empty bar line. The horizontal space between notes should be the same in both measures.

bar-line-define-bar-line-empty.ly

[image of music]

New bar line styles can be defined by \defineBarLine.

bar-line-define-bar-line.ly

[image of music]

Where \fine and \inStaffSegno occur together, user-defined bar lines can be printed by setting the fineSegnoBarType, fineStartRepeatSegnoBarType, endRepeatSegnoBarType, and doubleRepeatSegnoBarType context properties.

The output should show two adjacent repeated sections with doubled dots and thick bar lines, followed by a double thick bar line without dots. There should also be an in-staff segno in every case.

bar-line-define-fine-v-repeat-segno.ly

[image of music]

At \fine without \inStaffSegno, user-defined bar lines can be printed by setting the fineBarType, startRepeatBarType, endRepeatBarType, and doubleRepeatBarType context properties.

The output should show two adjacent repeated sections with doubled dots and thick bar lines, followed by a double thick bar line without dots.

bar-line-define-fine-v-repeat.ly

[image of music]

Customizing measureBarType is effective when appropriate bar lines are defined. The system should end with a single thick bar line with a dashed span.

bar-line-define-measure.ly

[image of music]

User-defined bar lines with in-staff segni can be printed by setting the segnoBarType, startRepeatSegnoBarType, endRepeatSegnoBarType, and doubleRepeatSegnoBarType context properties.

The output should show two adjacent repeated sections with unusually ornate bar lines with in-staff segni, followed by an in-staff segno that is flanked by thick bar lines.

bar-line-define-repeat-segno.ly

[image of music]

User-defined bar lines can be printed for \repeat volta by setting the startRepeatBarType, endRepeatBarType, and doubleRepeatBarType context properties.

This output should show two adjacent repeated sections with unusually ornate bar lines.

bar-line-define-repeat.ly

[image of music]

Customizing sectionBarType is effective when appropriate bar lines are defined. The system should end with a double bar line with a thick span.

bar-line-define-section.ly

[image of music]

Customizing underlyingRepeatBarType is effective when appropriate bar lines are defined. The first system should end with a single thick bar line with a dashed span.

bar-line-define-underlying-repeat.ly

[image of music]

A final volta bracket closes at \fine.

bar-line-fine-volta-hook.ly

[image of music]

\bar can override repeat bar lines. The first system should end with no bar line. The second system should begin with no bar line and end with a measure bar line.

bar-line-manual-v-repeat.ly

[image of music]

The markup command \bar-line scales nicely with different \fontsize. It is customizable by overriding height, dot-count, dash-count, kern or thick-thickness. The brace bar line sometimes emits a warning, if none exactly fitting can be found (this warning is not silenced here).

bar-line-markup.ly

[image of music]

An omitted bar line behaves like an empty bar line. The horizontal space between notes should be the same in both measures.

bar-line-omit.ly

[image of music]

This test shows the placement of the two-dot bar line element in various staff configurations.

bar-line-placement-colon.ly

[image of music]

The dashed bar line scales with different staff space, entered with layout-set-staff-size.

bar-line-placement-dashed-layout-staff-space.ly

[image of music]

The dashed bar line scales with different staff space, entered with \magnifyStaff.

bar-line-placement-dashed-magnify-staff-space.ly

[image of music]

This test shows the placement of dashed bar lines with span bars in various staff configurations and changed staff space via layout-set-staff-size.

bar-line-placement-dashed-span-layout-staff-space.ly

[image of music]

This test shows the placement of dashed bar lines with span bars in various staff configurations and changed staff space via \magnifyStaff.

bar-line-placement-dashed-span-magnify-staff-space.ly

[image of music]

This test shows the placement of dashed bar lines with span bars in various staff configurations and changed staff space via \override StaffSymbol.staff-space.

bar-line-placement-dashed-span-staff-space.ly

[image of music]

This test shows the placement of dashed bar lines with span bars in various staff configurations.

bar-line-placement-dashed-span.ly

[image of music]

The dashed bar line scales with different staff space, entered with \override StaffSymbol.staff-space.

bar-line-placement-dashed-staff-space.ly

[image of music]

A dashed bar line extends approximately as far as a normal bar line. The center-to-center distance between dashes is uniformly one staff space. At the vertical center of the staff is either a dash or the midpoint between dashes.

bar-line-placement-dashed.ly

[image of music]

The dotted bar line never exceeds a common bar line. This holds for different staff space, caused by layout-set-staff-size as well.

bar-line-placement-dotted-layout-staff-space.ly

[image of music]

The dotted bar line never exceeds a common bar line. This holds for different staff space, caused by \magnifyStaff as well.

bar-line-placement-dotted-magnify-staff-space.ly

[image of music]

The center-to-center distance between the dots in a dotted span bar line is approximately one staff space, taken from layout (not from the staff symbol). The dots of the span bar do not collide with staff lines or with the dots of in-staff bar lines. They never exceed the extent of the span bar (made visible by the thick span bar line). This holds for different staff space, caused by layout-set-staff-size as well.

bar-line-placement-dotted-span-layout-staff-space.ly

[image of music]

The center-to-center distance between the dots in a dotted span bar line is approximately one staff space, taken from layout (not from the staff symbol). The dots of the span bar do not collide with staff lines or with the dots of in-staff bar lines. They never exceed the extent of the span bar (made visible by the thick span bar line). This holds for different staff space, caused by \magnifyStaff as well.

bar-line-placement-dotted-span-magnify-staff-space.ly

[image of music]

The center-to-center distance between the dots in a dotted span bar line is approximately one staff space, taken from layout (not from the staff symbol). The dots of the span bar do not collide with staff lines or with the dots of in-staff bar lines. They never exceed the extent of the span bar (made visible by the thick span bar line). This holds for different staff space, caused by \override StaffSymbol.staff-space as well.

bar-line-placement-dotted-span-staff-space.ly

[image of music]

The center-to-center distance between the dots in a dotted span bar line is uniformly one staff space. The dots of the span bar do not collide with staff lines or with the dots of in-staff bar lines.

bar-line-placement-dotted-span.ly

[image of music]

The dotted bar line never exceeds a common bar line. This holds for different staff space, entered with \override StaffSymbol.staff-space as well.

bar-line-placement-dotted-staff-space.ly

[image of music]

The center-to-center distance between the dots in a dotted bar line is uniformly one staff space. At the vertical center of the staff is either a dot or the midpoint between dots, whichever places fewer dots on staff lines. The dotted bar line never exceeds a common bar line.

bar-line-placement-dotted.ly

[image of music]

The height of a short bar line is half the height of a normal bar line, rounded up to an integer number of staff spaces. It is usually centered vertically, but on very short staves, it is shifted down to distinguish it from a normal bar line.

bar-line-placement-short.ly

[image of music]

A tick bar line is a short line the length of a staff space. It is usually centered on the topmost bar line, but if there are fewer than two bar lines, it floats at the height of a normal bar line.

bar-line-placement-tick.ly

[image of music]

If different BarLine types are used at the same musical moment, setting BarLine.right-justified to #t right-aligns them. For a mid-line and right-aligned BarLine the anchor moves accordingly. At begin of line, BarLine is never right-aligned.

bar-line-right-justified.ly

[image of music]

\section creates a section bar line whether or not it is aligned on a measure boundary, except at the start of the piece. This test should show a double bar line after each of the three notes.

bar-line-section.ly

[image of music]

This test exercises bar lines that are overridden in various built-in Staff contexts. Each Staff is in a separate \score.

bar-line-staff-override-alone.ly

[image of music]

This test exercises bar lines that are overridden in various built-in Staff contexts. All staves are in one StaffGroup.

bar-line-staff-override-grouped.ly

[image of music]

Dashed and dotted bar lines print nicely with small values of set-global-staff-size and layout-set-staff-size.

bar-line-staff-size.ly

[image of music]

Bar lines account for user tweaks to staff symbol height.

bar-line-staff-symbol-height-override.ly

[image of music]

The hair-thickness property sets the thickness of thin bar lines, the thick-thickness property sets the thickness of thick bar lines, and the kern property sets the spacing within composite bar lines.

bar-line-thickness.ly

[image of music]

Automatic bar types that are set to '() or are unset are ignored, allowing lower-priority bar types to appear. In this case, there should be no line breaks and a single thick bar line should appear at the end under a segno.

bar-line-unset.ly

[image of music]

Various types of bar lines can be drawn.

The dashes in a dashed bar line covers staff lines exactly. Dashed bar lines between staves start and end on a half dash precisely.

The dots in a dotted bar line are in spaces.

A thick bar line is created by \bar ".", which is consistent with e.g. \bar "|."

A tick bar line is a short line of the same length as a staff space, centered on the top-most bar line.

A short bar line has a height of half the height of the staff, rounded up to an integer number of staff spaces. It is usually centered vertically, but on short staves, it is shifted down to distinguish it from a normal bar line.

bar-lines.ly

[image of music]

Each staff contains the same music, but with different values of alternativeNumberingStyle. The body of the repeat is a cadenza. The bar number at the start of each alternative should be parenthesized.

bar-number-after-alternative-restore-cadenza.ly

[image of music]

Each staff contains the same music, but with different values of alternativeNumberingStyle. The body of the repeat is a grace note. The bar number at the start of each alternative should be parenthesized.

bar-number-after-alternative-restore-grace.ly

[image of music]

In a measure beginning with grace notes and cadenza material, if a bar line is added at the end of the cadenza, its bar number is parenthesized even though the cadenza does not advance measurePosition.

The first staff tests this at the start of the first and following measures of a piece. The second staff tests this before an initial anacrusis.

bar-number-after-cadenza-with-grace.ly

[image of music]

In a measure beginning with cadenza material, if a bar line is added at the end of the cadenza, its bar number is parenthesized even though the cadenza does not advance measurePosition.

The first staff tests this at the start of the first and following measures of a piece. The second staff tests this before an initial anacrusis.

bar-number-after-cadenza.ly

[image of music]

When alternativeNumberingStyle is set to numbers-with-letters, the bar numbers in an alternative have a letter corresponding to the first volta number for the alternative.

bar-number-alternative-number.ly

[image of music]

The alternativeNumberingStyle context property controls the bar-numbering scheme and style in volta repeat alternatives.

bar-number-alternative-style.ly

[image of music]

Alignments for breakable items can have different values set for each break direction using the break-alignment-list function.

bar-number-break-alignment-list.ly

[image of music]

\barNumberCheck may be inserted to check whether the current bar number is correct. Checking is enabled by default for layout and disabled by default for MIDI.

bar-number-check-warning.ly

[image of music]

When there is a break without a bar line, a bar number can be printed nevertheless. Just like all bar numbers outside of measure boundaries, it is hidden by default, but it can be displayed using barNumberVisibility. On the other hand, a bar number resulting from a break point is not displayed if the break point does not become a break.

bar-number-no-bar-line.ly

[image of music]

oBreak does not prevent bar numbers from being printed.

bar-number-nobreak.ly

[image of music]

Alternative bar numbering does not apply to repeats in segno form. These measures should be numbered 1 to 3.

bar-number-segno-repeat.ly

[image of music]

Bar_number_engraver may be moved to staff-group contexts. Bar numbers should appear in black above the second staff from the top. The same numbers should appear in red above the third staff from the top.

bar-number-staff-group-context.ly

[image of music]

all-bar-numbers-visible is a bar number visibility where all bar numbers are printed, including bar numbers for the first measure and for broken measures.

bar-number-visibility-all-bar-numbers-visible.ly

[image of music]

every-nth-bar-number-visible is a bar number visibility generator that prints bar numbers at regular intervals of n: n, 2n, etc.

bar-number-visibility-every-nth-bar-number-visible.ly

[image of music]

first-bar-number-invisible-and-no-parenthesized-bar-numbers is a bar number visibility where bar numbers are printed except for the first, and except for broken measures.

bar-number-visibility-first-bar-number-invisible-and-no-parenthesized-bar-numbers.ly

[image of music]

first-bar-number-invisible-save-broken-bars is a bar number visibility that prints all bar numbers, including for broken bars, except for an unbroken number of the first bar.

bar-number-visibility-first-bar-number-invisible-save-broken-bars.ly

[image of music]

first-bar-number-invisible is a bar number visibility where all bar numbers can be printed, including for broken bars, except for the first measure, not even when broken.

bar-number-visibility-first-bar-number-invisible.ly

[image of music]

modulo-bar-number-visible is a bar number visibility generator that generalizes every-nth-bar-number-visible, printing bar numbers at regular intervals of n that do not necessarily start at n: k, k + n, k + 2n, etc.

bar-number-visibility-modulo-bar-number-visible.ly

[image of music]

numbers-with-letters bar numbering resets at the end of the repeat even if the repeat ends where no bar number is visible.

bar-number-volta-repeat-end.ly

[image of music]

Bar numbers can automatically reset at volta repeats.

bar-number-volta-repeat.ly

[image of music]

Bar numbers may be set and their padding adjusted individually. The counting of bar numbers is started after the anacrusis.

To prevent clashes at the beginning of a line, the padding may have to be increased.

bar-number.ly

[image of music]

A knee is made automatically when a horizontal beam fits in a gap between note heads that is larger than a predefined threshold.

beam-auto-knee.ly

[image of music]

There are presets for the auto-beam engraver in the case of common time signatures.

beam-auto.ly

[image of music]

beamlets don’t run to end of line if there are no other beamlets on the same height.

beam-beamlet-break.ly

[image of music]

Beamlets in grace notes remain readable.

beam-beamlet-grace.ly

[image of music]

Default beaming patterns can be set for the current time signature.

beam-beat-grouping.ly

[image of music]

Broken beams have sane endings even if grobs are not present at the broken end.

beam-break-no-bar.ly

[image of music]

Beams can be printed across line breaks, if forced.

beam-break.ly

[image of music]

Some classic examples of broken beams, all taken from Scriabin Op. 11, No. 1.

beam-broken-classic.ly

[image of music]

The functions passed to the positions property should handle complicated cases in the same manner that they handle more normal cases.

beam-broken-difficult.ly

[image of music]

Simple beams on middle staffline are allowed to be slightly sloped, even if the notes have ledgers. Beams reaching beyond middle line can have bigger slope.

beam-center-slope.ly

[image of music]

Beams only check for collisions with in-line accidentals.

beam-collision-accidentals.ly

[image of music]

Collisions between manual beams and notes are minimized.

beam-collision-basic.ly

[image of music]

Manual beams do not collide with notes.

beam-collision-beamcount.ly

[image of music]

Beam collisions from modern works

beam-collision-classic.ly

[image of music]

cross staff beams work with collisions.

beam-collision-cross-staff.ly

[image of music]

Cross staff beams do collision avoidance.

beam-collision-cross-staff2.ly

[image of music]

A rough guess for collisions is taken into account when choosing initial beam configurations; the initial position may be chosen to be either above or below large collisions.

beam-collision-feasible-region.ly

[image of music]

Beams do not collide with flags.

beam-collision-flag.ly

[image of music]

The beaming algorithm handles collisions between beams and grace notes too.

beam-collision-grace.ly

[image of music]

Behave sensibly in the presence of large collisions.

beam-collision-large-object.ly

[image of music]

Beams can be allowed to collide with grobs by overriding the collision-interfaces property.

beam-collision-off.ly

[image of music]

Meshing stems in oppositely directed beams are handled correctly.

beam-collision-opposite-stem.ly

[image of music]

Beams do not collide with clefs, key signatures, time signatures

beam-collision-prefatory-matter.ly

[image of music]

Beam collisions are resistant to scaled down staves.

beam-collision-scaled-staff.ly

[image of music]

Beam collision can be tweaked to only apply to the grobs within the beam’s original voice.

beam-collision-voice-only.ly

[image of music]

Concave beaming works for chords as well as monophonic music.

beam-concave-chord.ly

[image of music]

Beams that are not strictly concave are damped according to their concaveness.

beam-concave-damped.ly

[image of music]

Fully concave beams should be horizontal. Informally spoken, concave refers to the shape of the notes that are opposite a beam. If an up-beam has high notes on its center stems, then we call it concave.

If a beam fails a test, the desired slope is printed next to it.

beam-concave.ly

[image of music]

Automatic cross-staff knees work also (here they were produced with explicit staff switches).

beam-cross-staff-auto-knee.ly

[image of music]

Placement of beamed cross staff rests should be reasonably close to beam.

beam-cross-staff-rest.ly

[image of music]

scripts don’t trigger beam formatting. If this does happen, we can have a cyclic dependency on Y-positions of staves.

beam-cross-staff-script.ly

[image of music]

Cross staff (kneed) beams do not cause extreme slopes.

beam-cross-staff-slope.ly

[image of music]

Beams can be typeset over fixed distance aligned staves, beam beautification does not really work, but knees do. Beams should be behave well, wherever the switching point is.

beam-cross-staff.ly

[image of music]

Beams are less steep than the notes they encompass.

beam-damp.ly

[image of music]

Beamed stems have standard lengths if possible. Quantization is switched off in this example.

beam-default-lengths.ly

[image of music]

Beams should behave reasonably well, even under extreme circumstances. Stems may be short, but noteheads should never touch the beam. Note that under normal circumstances, these beams would get knees. Here Beam.auto-knee-gap was set to false.

beam-extreme.ly

[image of music]

Feathered beams should have the same progress of their feathering at the end of a line break as they do at the beginning of the next line.

beam-feather-breaking.ly

[image of music]

In feathered beams, stems in knees reach up to the feathered part correctly.

beam-feather-knee-stem-length.ly

[image of music]

Specifying grow-direction on a beam, will cause feathered beaming. The \featherDurations function can be used to adjust note durations.

beam-feather.ly

[image of music]

Even very flat but slanted patterns should give slanted beams.

beam-flat-retain-direction.ly

[image of music]

The direction of manual beams can be forced using _ and ^.

beam-forced-direction.ly

[image of music]

In French style beaming, the stems do not go between beams.

beam-french.ly

[image of music]

Funky kneed beams with beamlets also work. The beamlets should be pointing to the note head.

beam-funky-beamlet.ly

[image of music]

In complex configurations of knee beaming, according to Paul Roberts, the first stem of a beam determines the direction of the beam, and as such the way that following (kneed) stems attach to the beam. This is in disagreement with the current algorithm.

beam-funky.ly

[image of music]

Setting Timing.measureLength to infinity does not interfere with beaming grace notes.

beam-grace-infinite-measure-length.ly

[image of music]

A run of grace notes beginning with a tuplet is beamed and bracketed accordingly. The first three grace notes are a triplet with two beams. The last grace note is connected to them by one beam.

beam-grace-tuplet-bounds.ly

[image of music]

Beams can be placed across a PianoStaff.

beam-isknee.ly

[image of music]

Many complex knee beams that test peculiar edge cases (such as subdivision or # of beams changes by ≥ 2).

beam-knee-advanced.ly

[image of music]

Kneed beams of strictly monotone subdivisions should have their ’main beam’ be in the middle (outer beamlets of both sides converge to/diverge from middle)

beam-knee-different-levels.ly

[image of music]

Examples of kneed beams of varying complexity (based on how stem direction changes within a subdivision) all copied from pgs. 316-317 of Gould’s Behind Bars.

beam-knee-gould.ly

[image of music]

Kneed beams together with stemlets over rests work.

beam-knee-stemlet.ly

[image of music]

Point-symmetric beams should receive the same quanting. There is no up/down bias in the quanting code.

beam-knee-symmetry.ly

[image of music]

Beams should look the same.

beam-length.ly

[image of music]

Beaming can be overidden for individual stems.

beam-manual-beaming.ly

[image of music]

Kneed beams (often happens with cross-staff beams) should look good when there are multiple beams: all the beams should go on continuously at the staff change. Stems in both staves reach up to the last beam.

beam-multiple-cross-staff.ly

[image of music]

When a beam goes over a rest, beamlets should be as necessary to show the beat structure.

beam-multiplicity-over-rests.ly

[image of music]

Beams may overshoot stems. This is also controlled with break-overshoot.

beam-outside-beamlets.ly

[image of music]

Explicit beams may cross bar lines.

beam-over-barline.ly

[image of music]

Beams on ledgered notes should always reach the middle staff line. The second beam, counting from the note head side, should never be lower than the second staff line. This does not hold for grace note beams. Override with no-stem-extend.

beam-position.ly

[image of music]

This file tests a few standard beam quants, taken from Ted Ross’ book. If LilyPond finds another quant, the correct quant is printed over the beam.

beam-quant-standard.ly

[image of music]

Stem lengths take precedence over beam quants: ‘forbidden’ quants are only avoided for 32nd beams when they are outside of the staff. However, that leads to very long stems, which is even worse.

beam-quanting-32nd.ly

[image of music]

In this test for beam quant positions for horizontal beams, staff lines should be covered in all cases. For 32nd beams, the free stem lengths are between 2 and 1.5.

beam-quanting-horizontal.ly

[image of music]

Beam quanting accounts for beam overhang. A beam ending above rests should always fall on a viable quant (straddle, sit, inter, or hang).

beam-quanting-overhang.ly

[image of music]

Quarter notes may be beamed: the beam is halted momentarily.

beam-quarter.ly

[image of music]

Beamed rests are given a pure height approximation that gets their spacing correct in the majority of circumstances.

beam-rest-extreme.ly

[image of music]

The number of beams does not change on a rest.

beam-rest.ly

[image of music]

Engraving second intervals is tricky. We used to have problems with seconds being too steep, or getting too long stems. In a file like this, showing seconds, you’ll spot something fishy very quickly.

beam-second.ly

[image of music]

Beams in unnatural direction, have shortened stems, but do not look too short.

beam-shortened-lengths.ly

[image of music]

Single stem beams are also allowed. For such beams, clip-edges is switched off automatically.

beam-single-stem.ly

[image of music]

Beams over skips do not cause a segfault.

beam-skip.ly

[image of music]

For slope calculations, stemlets are treated as invisible stems.

beam-slope-stemlet.ly

[image of music]

Beam positioning and placement of articulations, fingerings, tuplet numbers, and slurs must be identical in standard and French beaming style.

beam-standard-french-compare.ly

[image of music]

Beams should subdivided as if there was no tuplet to consider in this particular case.

beam-subdivide-cancelling-tuplets.ly

[image of music]

Even under unusual measure lengths, beam subdivision should not defect.

beam-subdivide-compound-meter.ly

[image of music]

When subdividing tuplet ratios whose numerators are powers of 2, the beamlet removal depth of each subdivision should vary by the same level different, depending on the tuplet ratio magnitude.

beam-subdivide-duplets.ly

[image of music]

Beam count at subdivisions should match the count corresponding to the location of the current subdivision. However, if the remainder of the beam is shorter than that and incomplete beams are respected, the beam count should be adopted accordingly.

beam-subdivide-incomplete-beam.ly

[image of music]

When beamMaximumSubdivision < beamMinimumSubdivision, the subdivision depth should respect the limit imposed by beamMaximumSubdivision even if it is not metrically correct.

beam-subdivide-max-limit.ly

[image of music]

A triplet of any level should clearly subdivide its 3 beats at its topmost level, and any subdivisions (of powers of  2) of those beats should be at their own level strictly lower than said topmost level.

beam-subdivide-nested-triplets.ly

[image of music]

The default subdivision of a pentadecuplet should be none as the hamming weight of the denominator is more than 1.

beam-subdivide-pentadecuplet.ly

[image of music]

Beam count at subdivisions should match the location of the current subdivision. However, if the groups are equal or longer than quarter notes, one beam should always be left.

beam-subdivide-quarter-notes.ly

[image of music]

At position 1/8, the beam should be subdivided at the 1/16 level due to the time signature.

beam-subdivide-three-numerator-meter.ly

[image of music]

If in a subdivided beam one single stem follows a subdivision the beam count should reflect the beam count of the subdivision as usual. That is, the beam count should not be increased according to the remaining length of the beam. The appended single stem has beamlets to the left.

beam-subdivide-trailing-stem.ly

[image of music]

Even though their tuplet ratios are the same when simplified each additional power of 2 in the tuplet numerator subdivides an additional half.

beam-subdivide-triplet-variants.ly

[image of music]

Stems at boundaries of tuplet spans must have one side subdivided from a perspective outside of said tuplet span.

beam-subdivide-tuplet-boundaries.ly

[image of music]

Beamed grace notes within a tuplet should be subdivided independently from the tuplet. Each of the 3 beams of the second tuplet, where beam subdivision is enabled, should have 2 subdivisions at 16th level, 1 subdivision at 8th level.

beam-subdivide-tuplet-grace.ly

[image of music]

Tuplets that span more than one beat should be subdivided if subdivideBeams is #t. In this example, the beams should be subdivided every 1/8.

beam-subdivide-tuplets.ly

[image of music]

Properties beamMaximumSubdivision and beamMinimumSubdivision may have a non-power of 2 numerator. If beamMaximumSubdivision does have non-power-of-2  numerator, let n be the largest odd factor of that numerator. The beamlets should be subdivided n times less frequently than as if n was 1. Since beamMinimumSubdivision only sets a lower bound for intervals of subdivision interval, it having a non-power-of-2 numerator is not much any different from an approriate power-of-2 counterpart.

beam-subdivide-unusual-subdivision-intervals.ly

[image of music]

Beam count at subdivisions should match the location of the current subdivision.

beam-subdivision.ly

[image of music]

By setting max-beam-connect, it is possible to create pairs of unconnected beamlets.

beam-unconnected-beamlets.ly

[image of music]

An unterminated manual beam generates a warning. This test should run with expected warnings only.

beam-unterminated.ly

[image of music]

Inside-staff beams should align with staff lines (sit, straddle, hang) as smoothly as possible (standard-sized beams). The outside-staff beams do not interfere with staff lines, so the inside-staff beams are more important when it comes to beam quanting/scoring/positioning.

beaming-more-than-4-beams-normal-size.ly

[image of music]

Automatic beaming works also in ternary time sigs. As desired, the measure is split in half, with beats 1-3 and 4-6 beamed together as a whole.

beaming-ternary-metrum.ly

[image of music]

Beams in a completed tuplet should be continuous.

beaming-tuplet-regular.ly

[image of music]

Beaming is generated automatically. Beams may cross bar lines. In that case, line breaks are forbidden.

beaming.ly

[image of music]

Beamlets can be set to point in the direction of the beat to which they belong. The first beam avoids sticking out flags (the default); the second beam strictly follows the beat.

beamlet-point-toward-beat.ly

[image of music]

Beamlets should point away from complete beat units and toward off-beat or broken beat units. This should work in tuplets as well as in ordinary time.

beamlet-test.ly

[image of music]

Beaming can be also given explicitly.

beams.ly

[image of music]

Show the effect of the Beat_performer on drum tremolos: start of the bar and its beats are marked by \marcato and \accent, respectively, unless manual syncopes in less distance than the last ‘regular’ beat precede, indicated with one of those two articulations explicitly.

beat-performer.ly

[image of music]

Falls and doits terminate correctly on the next note, even when started inside a \grace.

bend-after-start-in-grace.ly

[image of music]

Falls and doits can be created with \bendAfter. They run to the next note, or to the next bar line. Microtone bends like \bendAfter 3.5 are also supported.

bend-after.ly

[image of music]

Bends should not be affected by the full width of a NonMusicalPaperColumn. The bends should have identical X spans in the two scores. No bends should cross bar lines.

bend-bound.ly

[image of music]

Bends avoid dots, but only if necessary.

bend-dot.ly

[image of music]

Multiple consecutive BendSpanner grobs work. Every BendSpanner following another one starts at the arrow head of the previous one or at a TabNoteHead.

bend-spanner-consecutive.ly

[image of music]

A BendSpanner may be customized by tweaking the subproperties of 'details.

  • 'bend-arrowhead-height
  • 'bend-arrowhead-width
  • 'arrow-stencil best to override it with a procedure (as an argument to the after-line-breaking property) setting this subproperty.
  • 'curvature-factor
  • 'bend-amount-strings
  • 'dashed-line-settings
  • 'horizontal-left-padding
  • 'vertical-padding
  • 'y-distance-from-tabstaff-to-arrow-tip
  • 'target-visibility

Line-breaking behavior may be customized with:

  • 'curve-x-padding-line-end
  • 'curve-y-padding-line-end
  • 'head-text-break-visibility

bend-spanner-details.ly

[image of music]

Per default notes played on open strings are disregarded by BendSpanner unless the property 'bend-me is set to true for this note. Other notes may be excluded by setting the property 'bend-me to false.

bend-spanner-exclude-notes.ly

[image of music]

At a line break the BendSpanner avoids changed TimeSignature, KeySignature, KeyCancellation and Clef in other staves.

bend-spanner-line-break.ly

[image of music]

A BendSpanner prints a line and/or curve to a certain point above the TabStaff or above the target TabNoteHead. This line or curve ends in an arrow head. For an up-pointing BendSpanner the amount of bending is printed above the arrow head. For a down-pointing BendSpanner the target TabNoteHead will be parenthesized. Works at line breaks.

bend-spanner-simple.ly

[image of music]

BendSpanner scales according to different staff sizes.

bend-spanner-staff-size.ly

[image of music]

BendSpanner can be used in different styles: the default, 'hold, printing a dashed line (only useful in combination with a previous BendSpanner), 'pre-bend, printing a vertical line, and 'pre-bend-hold, printing a vertical line continued by a dashed horizontal line.

The 'style property may be set using \tweak, \override or one of \bendHold, \preBend and \preBendHold.

bend-spanner-styles.ly

[image of music]

BendSpanner may be started at a tied note. To skip tied notes NoteColumn.bend-me should be set to false. The following BendSpanner continues without a gap.

bend-spanner-tied-notes.ly

[image of music]

This input file contains a UTF-8 BOM not at the very beginning, but on the first line after the first byte. LilyPond should gracefully ignore this BOM as specified in RFC 3629, but print a warning.

bom-mark.ly

[image of music]

Changing global-staff-size between consecutive \books must not impair font spacing. While the Pango fonts stay the same and may be re-used, the internal LilyPond scaling factor will not be correct any more. Not only \abs-fontsize, but even \fontsize (in extreme cases) will be affected. The following output shows a 10pt book after a standard 20pt book:

book-change-global-staffsize-abs-fonts.ly

[image of music]

A \book or \bookpart identifier can contain top-level markup and page-markers.

book-identifier-markup.ly

[image of music]

A book(part) can contain only a label without causing a segfault.

book-label-no-segfault.ly

[image of music]

It is possible for one bookpart to have its independent page numbers while the others have a common sequence of page numbers.

bookpart-level-page-numbering-one-bookpart.ly

[image of music]

Pages can be numbered per bookpart rather than per book.

bookpart-level-page-numbering.ly

[image of music]

bookpart-variable.ly

[image of music]

A book can be split into several parts with different paper settings, using \bookpart.

Fonts are loaded into the top-level paper. Page labels are also collected into the top-level paper.

bookparts.ly

[image of music]

The default callback for break-align-anchor in clefs and time/key signatures reads the break-align-anchor-aligment property to align the anchor to the extent of the break-aligned grob.

break-alignment-anchor-alignment.ly

[image of music]

In this case, the compound time signature has a CENTER (0) anchor point and the 1/1 time signature has a LEFT (1) anchor point. The midpoint of these is 0.75, but it is not used for the “average” anchor point of the group because it would fall outside the range of anchor points that the isolated time signatures would choose. Instead, the average anchor point is the closer extreme of that range, which is the center of the compound time signature. The arrow should point there.

break-alignment-anchor-average-clamp.ly

[image of music]

The “average” anchor of a diverse group of break-aligned items depends on the range of the particular anchors, but not on the number of items. In this case, the arrows should appear at the same horizontal position in both measures though the 1/1 time signature appears twice in one measure and only once in the next.

break-alignment-anchor-average-midpoint.ly

[image of music]

When a group of break-aligned items agree on the position of their own anchors with respect to their own extents, the “average” anchor of the group falls at that position with respect to the extent of the group. In this case, each rehearsal mark should point to the stated point relative to the compound time signature.

break-alignment-anchor-average-unanimous.ly

[image of music]

The break-align-anchor property of a break-aligned grob gives the horizontal offset at which other grobs should attach.

break-alignment-anchors.ly

[image of music]

A Dynamics context over a Staff does not impact the spacing of bar numbers relative to the staff at a line break. Bar number 2 should appear in its usual spot.

break-alignment-dynamics-over-staff.ly

[image of music]

\break forces a break, even in circumstances where LilyPond would normally not allow a break.

break-bypass-default-break-points.ly

[image of music]

A clef is printed at a break, even without a bar line.

break-no-bar-clef.ly

[image of music]

A key signature is printed at a break, even without a bar line.

break-no-bar-key.ly

[image of music]

Breaks can be encouraged and discouraged using \break and \noBreak.

break.ly

[image of music]

The breathMarkType context property controls the sign that \breathe produces. The output should show two default breathing signs then two tick marks (check marks).

breath-mark-type.ly

[image of music]

Breathing signs do not collide with accidentals.

breathing-sign-accidentals.ly

[image of music]

Gregorian chant notation sometimes also uses commas and ticks, but in smaller font size (we call it ‘virgula’ and ‘caesura’). However, the most common breathing signs are divisio minima/maior/maxima and finalis, the latter three looking similar to bar glyphs.

breathing-sign-ancient.ly

[image of music]

Breathing signs are positioned correctly on custom staves which use line-positions.

breathing-sign-custom-staff.ly

[image of music]

Breathing signs do not collide with note heads even in very constrained spacing situations.

breathing-sign-tight-spacing.ly

[image of music]

This test shows the predefined values available for context properties that specify a type of BreathingSign. The dotted lines are bar lines.

breathing-sign-types-one-voice.ly

[image of music]

Breathing signs are available in different tastes: commas (default), ticks, vees and ‘railroad tracks’ (caesura).

breathing-sign.ly

[image of music]

LilyPond knows that breves and longas are wider than whole notes (because of vertical lines on their sides). Breves and longas don’t collide with accidentals, bar lines, neighbor notes, etc. The distance between accidental and note is the same for whole notes, breves and longas.

breve-extent.ly

[image of music]

A grace note after \cadenzaOff does not keep autobeaming from resuming properly.

cadenza-grace-autobeam.ly

[image of music]

Caesura scripts can align to breath marks in some staves and to bar lines in others. The output should have one staff with a fermata over ‘railroad tracks’. The other staves should have a fermata over a comma at bar lines, and the scripts should align to the bar lines individually.

caesura-alignment-multiple.ly

[image of music]

Articulations following \caesura are stacked according to the same priorities as articulations following notes. These articulations should look the same though the input order is different each time.

caesura-articulation-multiple.ly

[image of music]

In staff groups where span bar lines are engraved, caesura marks aligned on bar lines appear outside the extremal staves only, even at points where no span bar is visible.

The top PianoStaff should not have fermatas between the staves where the other PianoStaff and ChoirStaffs do.

caesura-over-span-bar-line.ly

[image of music]

A caesura script is automatically shifted up to avoid colliding with a tall bar line.

caesura-over-tall-bar-line.ly

[image of music]

Context modifications can make \caesura appear as a stack of scripts. In this case, the caesura itself is engraved as a fermata over a comma, and a double-dot fermata is added as an articulation. The final caesura is colored red with \tweak … \caesura …, which affects both the fermata and the comma, but not the additional articulation.

caesura-script-multiple.ly

[image of music]

This test customization of \caesura. In mid measure, the caesura appears as a comma outside the staff. At a bar line, no caesura mark appears, but optional articulations still appear.

caesura-style-comma-not-at-bar-line.ly

[image of music]

This test customization of \caesura. In mid measure, the caesura appears as a comma outside the staff. At a bar line it appears as a fermata.

caesura-style-comma-or-fermata.ly

[image of music]

Context modifications can make \caesura appear as a comma outside the staff. In this case, when the caesura comes at a measure boundary, the comma is aligned over the bar line rather than like a breath mark.

caesura-style-comma-over-bar-line.ly

[image of music]

Context modifications can make \caesura appear as a comma outside the staff. In this case, all commas are horizontally aligned like breath marks, even when the caesura comes at a measure boundary.

caesura-style-comma.ly

[image of music]

This test shows the default caesura mark style.

caesura-style-default.ly

[image of music]

This test customization of \caesura. In mid measure, the caesura appears as ‘railroad tracks’. At a bar line it appears as a fermata.

caesura-style-straight-or-fermata.ly

[image of music]

Long titles should be properly centered.

center-title.ly

[image of music]

Centered bar numbers may be altered according to alternatives just like regular bar numbers.

centered-bar-numbers-alternative.ly

[image of music]

The centering of measure-centered bar numbers does not take prefatory material (such as clefs and time signatures) into account in the extent of the measure. This may be overridden by the user.

centered-bar-numbers-centering.ly

[image of music]

Measure-centered bar numbers may be placed beneath the staves.

centered-bar-numbers-down.ly

[image of music]

Centered bar numbers may be boxed or circled. Their appearance can be changed through properties of the text-interface.

centered-bar-numbers-formatting.ly

[image of music]

Test the stacking of measure-centered bar numbers with other objects.

centered-bar-numbers-priority.ly

[image of music]

self-alignment-X can be overridden on centered bar numbers.

centered-bar-numbers-self-alignment-X.ly

[image of music]

Centered bar numbers honor the barNumberVisibility context property.

centered-bar-numbers-visibility.ly

[image of music]

Bar numbers may be centered within their measure.

centered-bar-numbers.ly

[image of music]

In ChoirStaff contexts, dynamics are allowed to cross columns.

choirstaff-dynamics-spacing.ly

[image of music]

Chords containing unisons or seconds: Center articulation marks, dynamics, slurs, etc., on the notehead that is on the “correct” side of the stem.

chord-X-align-on-main-noteheads.ly

[image of music]

The prefix of additional chord pitches can be tuned with additionalPitchPrefix.

chord-additional-pitch-prefix.ly

[image of music]

Chord change detection in repeat alternatives happens in relation to the chord active at the beginning of the first alternative.

chord-changes-alternative.ly

[image of music]

Property chordChanges: display chord names only when there’s a change in the chords scheme, but always display the chord name after a line break.

chord-changes.ly

[image of music]

The column of dots on a chord is limited to the height of the chord plus chord-dots-limit staff-positions.

chord-dots.ly

[image of music]

Contexts can be created in parallel with ChordGrid by instantiating a ChordGridScore explicitly.

chord-grid-additional-contexts.ly

[image of music]

In chord grids, lines inside squares attach to the innermost line of the bar line.

chord-grid-bar-line-attachment.ly

[image of music]

Various kinds of marks can be used within ChordGrid contexts.

chord-grid-marks.ly

[image of music]

In chord grids, the \medianChordGridStyle command causes measures split in 4 equal parts to be printed with median rather than diagonal lines. This is the style recommended in Philippe Baudoin’s book Jazz, mode d’emploi.

chord-grid-median-style.ly

[image of music]

Individual chords can be parenthesized in chord grids.

chord-grid-parentheses.ly

[image of music]

Repeat notation can be used in chord grids.

For volta repeats, a repeat bar line is printed even at the beginning of the piece. Inner lines in the chord square should stop at the ‘|’ part of the ‘.|:’ bar line, not at ‘:’.

chord-grid-repeats.ly

[image of music]

Chord grids can contain rests. This causes the noChordSymbol to be printed.

chord-grid-rests.ly

[image of music]

Chord grids may contain skips. They cause a blank space in chord squares.

chord-grid-skips.ly

[image of music]

Chord grids are properly scaled with staff size.

chord-grid-staff-sizes.ly

[image of music]

\stopStaff and \startStaff can be used in chord grids.

chord-grid-stopstaff.ly

[image of music]

Within chord grids, an unterminated measure should be handled gracefully.

chord-grid-unterminated-measure.ly

[image of music]

The ChordGrid context creates chord grid notation.

chord-grid.ly

[image of music]

The 11 is only added to major-13 if it is mentioned explicitly.

chord-name-11-entry.ly

[image of music]

Chords can be produced with the chordname entry code (\chordmode mode), using a pitch and a suffix. Here, the suffixes are printed below pitches.

chord-name-entry.ly

[image of music]

The property chordNameExceptions can used to store a list of special notations for specific chords.

chord-name-exceptions.ly

[image of music]

The layout of the major 7 can be tuned with majorSevenSymbol. It does not break if majorSevenSymbol is unset. One should see: triangle - j7 - triangle - #7.

chord-name-major7.ly

[image of music]

The layout of the minor chord can be tuned with minorChordModifier.

chord-name-minor.ly

[image of music]

Users can override the text property of ChordName.

chord-name-override-text.ly

[image of music]

In ignatzek inversions, a note is dropped down to act as the bass note of the chord. Bass note may be also added explicitly. Above the staff: computed chord names. Below staff: entered chord name.

chord-names-bass.ly

[image of music]

GrandStaff contexts accept chord names. The chord name in this example should be printed above the top staff.

chord-names-in-grand-staff.ly

[image of music]

The english naming of chords (default) can be changed to german (\germanChords replaces B and Bes to H and B), semi-german (\semiGermanChords replaces B and Bes to H and Bb), italian (\italianChords uses Do Re Mi Fa Sol La Si), or french (\frenchChords replaces Re to Ré).

chord-names-languages.ly

[image of music]

Minor chords may be printed as lowercase letters, in which case the ‘m’ suffix is omitted in the output.

chord-names-lower-case-minor.ly

[image of music]

In ChordNames, both normal rests and multi-measure rests cause noChordSymbol to be printed. Skips do not print anything.

chord-names-rests.ly

[image of music]

The Span_bar_stub_engraver also works with ChordNames contexts, ensuring that chord names remain clear of span bars.

chord-names-spanbar.ly

[image of music]

Chord repeats should omit forced and reminder accidentals.

chord-repetition-accidentals.ly

[image of music]

Chord repetition handles \relative mode: the repeated chords have the same octaves as the original one.

chord-repetition-relative.ly

[image of music]

Post events such as fingerings and scripts added to a chord repetition follow the same basic stacking order as chords.

chord-repetition-script-stack.ly

[image of music]

Chord repetitions are expanded late in the processing order and get their note events only then. Check that \times still works correctly on them.

chord-repetition-times.ly

[image of music]

\tweak takes effect on repeat chords ‘q’ just as if the repetition were written out. In this test, the two first scores should be identical, and the third score should be identical to the first two except for two added dynamic markings. The stems should be thicker than usual, and note heads in the second chord and the third one should be bigger.

chord-repetition-tweak.ly

[image of music]

A repetition symbol can be used to repeat the previous chord and save typing. Only note events are copied: articulations, text scripts, fingerings, etc are not repeated.

chord-repetition.ly

[image of music]

Scripts can also be attached to chord elements. They obey manual direction indicators.

chord-scripts.ly

[image of music]

The layout of chord inversions can be tuned with slashChordSeparator.

chord-slash-separator.ly

[image of music]

Chord tremolos adapt to the presence of accidentals.

chord-tremolo-accidental.ly

[image of music]

Articulations on chord tremolos should not confuse the time-scaling of the notes. In particular, only the number of real notes should be considered.

chord-tremolo-articulations.ly

[image of music]

To calculate the total duration of chord tremolos, only real notes shall be counted, no other commands.

chord-tremolo-other-commands.ly

[image of music]

Don’t allow scaled durations to confuse the tremolo beaming. The tremolos should each have 3 beams.

chord-tremolo-scaled-durations.ly

[image of music]

Tremolo repeats can be constructed for short tremolos (total duration smaller than 1/4) too. Only some of the beams are connected to the stems.

chord-tremolo-short.ly

[image of music]

Chord tremolos on a single note.

chord-tremolo-single.ly

[image of music]

Stem directions influence positioning of whole note tremolo beams.

chord-tremolo-stem-direction.ly

[image of music]

chord tremolos don’t collide with whole notes.

chord-tremolo-whole.ly

[image of music]

Chord tremolos look like beams, but are a kind of repeat symbol. To avoid confusion, chord tremolo beams do not reach the stems, but leave a gap. Chord tremolo beams on half notes are not ambiguous, as half notes cannot appear in a regular beam, and should reach the stems.

In this example, each tremolo lasts exactly one measure.

(To ensure that the spacing engine is not confused we add some regular notes as well.)

chord-tremolo.ly

[image of music]

Chord voicings may be transformed or inverted automatically through Scheme functions. These work even when chord notes are not entered in order (e.g. from the lowest to the uppermost note), and may also be used in chordmode. Even when using voicings, chord names remain unchanged.

chord-voicings.ly

[image of music]

Rests in music passed to ChordNames context display noChordSymbol. noChordSymbol is treated like a ChordName with respect to chordChanges.

chordnames-nochord.ly

[image of music]

Jazz chords may have unusual combinations.

chords-funky-ignatzek.ly

[image of music]

staffLineLayoutFunction is used to change the position of the notes. This sets staffLineLayoutFunction to ly:pitch-semitones to produce a chromatic scale with the distance between a consecutive space and line equal to one semitone.

chromatic-scales.ly

[image of music]

A clef change at the end of the music is printed.

clef-change-at-end.ly

[image of music]

Setting forceClef prints a clef, even at the end of the music, even if the clef is unchanged, and even without a \clef command.

clef-force.ly

[image of music]

Ottava brackets and clefs both modify Staff.middleCPosition, but they don’t confuse one another.

clef-ottava.ly

[image of music]

Clef transposition symbols may be parenthesized or bracketed by using parentheses or brackets in the command string.

clef-transposition-optional.ly

[image of music]

Transposition symbols should be correctly positioned close to the parent clef. Horizontal alignment is fine-tuned for standard C, G and F clefs: for example, downwards transposition of a G clef should be centered exactly under the middle of clef hook. For clefs that don’t have fine-tuned alignment the transposition number should be centered.

clef-transposition-placement.ly

[image of music]

Clefs may be transposed. By default, break-visibility of ClefModifiers is derived from the associated clef, but it may be overridden explicitly. The initial treble_8 clef should not have an 8, while the treble_8 clef after the tenor clef should. These settings also need to apply to clefs on new lines.

clef-transposition-visibility.ly

[image of music]

Clefs may be transposed up or down by arbitrary amount, including 15 for two octaves.

clef-transposition.ly

[image of music]

The \clef command does not print a clef if the clef has not changed. Only the system-start clef should appear.

clef-unchanged.ly

[image of music]

Unknown clef name warning displays available clefs

clef-warn.ly

[image of music]

Clefs with full-size-change should be typeset in full size.

clefs.ly

[image of music]

Clipping snippets from a finished score

Notes:

  • If system starts and ends are included, they include extents of the System grob, eg. instrument names.
  • Grace notes at the end point of the region are not included
  • Regions can span multiple systems. In this case, multiple EPS files are generated.

This file needs to be run separately with -dclip-systems; the collated-files.html of the regression test does not adequately show the results.

The result will be files named base-from-start-to-end[-count].eps.

When using Cairo, this file only works when using the PostScript format.

clip-systems.ly

[image of music]

Clusters behave well across line breaks.

cluster-break.ly

[image of music]

Clusters can be written across staves.

cluster-cross-staff.ly

[image of music]

don’t crash on single chord clusters.

cluster-single-note.ly

[image of music]

Clusters behave well across line breaks.

cluster-style.ly

[image of music]

Clusters are a device to denote that a complete range of notes is to be played.

cluster.ly

[image of music]

\codaMark \default at the beginning of the score does not create a mark. A single coda mark should appear at the beginning of the second measure and a double coda mark should appear at the end.

coda-mark-begin-score-default.ly

[image of music]

\codaMark 1 at the beginning of the score creates a visible mark. A single coda mark should appear at the beginning of the measure and a double coda mark should appear at the end.

coda-mark-begin-score-specific.ly

[image of music]

A coda mark at a line break appears at the end of the line.

coda-mark-break.ly

[image of music]

Coda marks are formatted with codaMarkFormatter, which the user can override. Rehearsal marks and coda marks are sequenced independently.

coda-mark-formatters.ly

[image of music]

Where a coda mark is not aligned on a measure boundary, the bar line defined by underlyingRepeatBarType appears by default. In this case, the single coda sign should have a normal bar line and the double coda sign should have a dotted bar line.

coda-mark-unaligned.ly

[image of music]

When notes are colliding, the resolution depends on the dots: notes with dots should go to the right, if there could be confusion to which notes the dots belong.

collision-dots-invert.ly

[image of music]

If dotted note heads must remain on the left side, collision resolution moves the dots to the right.

collision-dots-move.ly

[image of music]

For collisions where the upper note is dotted and in a space, the upper is moved to right. This behavior can be tuned by prefer-dotted-right.

collision-dots-up-space-dotted.ly

[image of music]

Collision resolution tries to put notes with dots on the right side.

collision-dots.ly

[image of music]

Collision resolution involving dotted harmonic heads succeeds when dots are hidden since rhythmic-head-interface will only retrieve 'dot-count from live grobs.

collision-harmonic-no-dots.ly

[image of music]

Note heads in collisions should be merged if they have the same positions in the extreme note heads.

collision-head-chords.ly

[image of music]

‘fa’ shape note heads (‘fa’, ‘faThin’, etc.), which are right triangles, are merged to avoid creating a rectangular note.

Using property NoteCollision.fa-merge-direction, the direction of the merged ‘fa’ can be controlled independently of the stem direction. If this property is not set, the ‘down’ glyph variant is used.

collision-head-solfa-fa.ly

[image of music]

Open and black note heads are not merged by default.

collision-heads.ly

[image of music]

Colliding note-columns may be shifted manually with force-hshift. Arrangements of notes after collision-resolution have their main columns (not suspended notes) left-aligned, excluding columns with forced shifts.

collision-manual.ly

[image of music]

If NoteCollision has merge-differently-dotted = ##t note heads that have differing dot counts may be merged anyway. Dots should not disappear when merging similar note heads.

collision-merge-differently-dotted.ly

[image of music]

If merge-differently-headed is enabled, then open note heads may be merged with black noteheads, but only if the black note heads are from 8th or shorter notes.

collision-merge-differently-headed.ly

[image of music]

When merging heads, the dots are merged too.

collision-merge-dots.ly

[image of music]

Oppositely stemmed chords, meshing into each other, are resolved.

collision-mesh.ly

[image of music]

Seconds do not confuse the collision algorithm. The first pair of chords in each measure should merge, mesh, or come relatively close, but the second in each measure needs more space to make clear which notes belong to which voice.

collision-seconds.ly

[image of music]

Single head notes may collide.

collision-single-head.ly

[image of music]

Mixed collisions with whole and longer notes require asymmetric shifts.

collision-whole.ly

[image of music]

In addition to normal collision rules, there is support for polyphony, where the collisions are avoided by shifting middle voices horizontally.

collisions.ly

[image of music]

CSS-style color codes are supported and must be prefixed with a hash. In SVG backend, the given color codes (as hexadecimal strings or predefined color names) are used directly; rgb-color lists are converted to rgb() or rgba() appropriately.

Alpha transparency is only visible in SVG output.

color-css.ly

[image of music]

Each grob can have a color assigned to it. Use the \override and \revert expressions to set the color property.

Colors may include an alpha channel, but that is only apparent in SVG output.

color.ly

[image of music]

Complex completion heads work properly in a polyphonic environment.

completion-heads-alternating-polyphony.ly

[image of music]

The Completion_heads_engraver uses dotted breve/longa durations if possible.

completion-heads-dotted-durations.ly

[image of music]

If the Note_heads_engraver is replaced by the Completion_heads_engraver, long notes, longer than measureLength, are split into un-scaled notes, even if the original note used a scale-factor. completionFactor controls this behavior.

completion-heads-factor.ly

[image of music]

You can put lyrics under completion heads.

completion-heads-lyrics.ly

[image of music]

The Completion_heads_engraver correctly handles notes that need to be split into more than 2 parts.

completion-heads-multiple-ties.ly

[image of music]

Completion heads are broken across bar lines. This was intended as a debugging tool, but it can be used to ease music entry. Completion heads are not fooled by polyphony with a different rhythm.

completion-heads-polyphony.ly

[image of music]

Completion heads will remember ties, so they are started on the last note of the split note.

completion-heads-tie.ly

[image of music]

Completion heads may be used with tuplets (and compressed music) too.

completion-heads-tuplets.ly

[image of music]

Note head completion may be broken into sub-bar units by setting the completionUnit property.

completion-heads-unit.ly

[image of music]

If the Note_heads_engraver is replaced by the Completion_heads_engraver, notes that cross bar lines are split into tied notes.

completion-heads.ly

[image of music]

If the Rest_engraver is replaced by the Completion_rest_engraver, long rests, longer than measureLength, are split into un-scaled rests, even if the original duration used a scale-factor. completionFactor controls this behavior.

completion-rest.ly

[image of music]

This tests \once applied to multiple property operations.

complex-once.ly

[image of music]

Simple-fraction components of a compound time signature are numeric regardless of the time signature style.

compound-time-signature-style.ly

[image of music]

Create compound time signatures. The argument is a Scheme list of lists. Each list describes one fraction, with the last entry being the denominator, while the first entries describe the summands in the enumerator. If the time signature consists of just one fraction, the list can be given directly, i.e. not as a list containing a single list. For example, a time signature of (3+1)/8 + 2/4 would be created as \compoundMeter #'((3 1 8) (2 4)), and a time signature of (3+2)/8 as \compoundMeter #'((3 2 8)) or shorter \compoundMeter #'(3 2 8).

compound-time-signatures.ly

[image of music]

A \defaultchild cycle does not induce an endless loop. The output of this test is not important.

context-defaultchild-cycle.ly

[image of music]

\defaultchild can be overridden in a context definition. CREATED should appear in the left margin.

context-defaultchild-def.ly

[image of music]

\defaultchild can be overridden in \with blocks. CREATED should appear in the left margin.

context-defaultchild-mod.ly

[image of music]

\denies context in a context definition cancels a prior \defaultchild context. CREATED should appear in the left margin.

context-denies-defaultchild-def.ly

[image of music]

\denies context in a \with block cancels a prior \defaultchild context. CREATED should appear in the left margin.

context-denies-defaultchild-mod.ly

[image of music]

A \denies statement in a \with block applies to the local context only; it does not change the global context definition. The lower staff should hold a B-sharp.

context-denies-nondestructive-mod.ly

[image of music]

If the descend-to-context function cannot find or create its context below the current context, then it does not create its context anywhere, and it leaves the current context unchanged.

The expected output of this test is one staff with two notes.

context-descend-only-not-found.ly

[image of music]

a staff should die if there is reference to it.

context-die-staff.ly

[image of music]

\context finds a child by type and ID even when the parent also matches.

    StaffGroup A
       \
      StaffGroup B (from here, find StaffGroup A)
         \
        StaffGroup A (this is found)

RESULT should appear in the left margin.

context-find-child.ly

[image of music]

\context finds the current context by type and ID even when there are matching contexts both above and below.

    StaffGroup A
       \
      StaffGroup A (from here, find StaffGroup A)
         \
        StaffGroup A

INNER and RESULT should appear in the left margin.

context-find-current.ly

[image of music]

\context finds a grandchild by type and ID when there are multiple matching contexts.

           StaffGroup A (from here, find Staff D)
          /            \
    StaffGroup B  StaffGroup C
        /                \
    Staff D            Staff D

RESULT and either B or C should appear in the left margin.

context-find-grandchild-ambiguous.ly

[image of music]

\context finds a grandchild by type and ID even when the parent also matches.

    StaffGroup A
       \
      StaffGroup B (from here, find StaffGroup A)
         \
        StaffGroup C
           \
          StaffGroup A (this is found)

RESULT should appear in the left margin.

context-find-grandchild.ly

[image of music]

\context can find the parent context by type and ID.

    StaffGroup A
       \
      StaffGroup B (from here, find StaffGroup A)

CHILD and RESULT should appear in the left margin.

context-find-parent.ly

[image of music]

Attempting to find a Score context by alias before it exists triggers creation of a Score context. The output should have a note on the middle line of the staff.

context-find-score-alias.ly

[image of music]

\context creates a new context rather than finding a matching context in another branch.

             StaffGroup A
            /          \
     StaffGroup B  StaffGroup C (from here, find StaffGroup B)
                         \
                       [StaffGroup B] (this is created)

B1, A, C, and B2 should appear in the left margin.

context-find-sibling.ly

[image of music]

User code is not allowed to access the Global context. The visual output of this test is not important.

context-global-find.ly

[image of music]

User code is not allowed to create a Global context. The visual output of this test is not important.

context-global-new.ly

[image of music]

Context modifications can be stored into a variable as a \with object. They can be later inserted directly into a context definition.

context-mod-context.ly

[image of music]

Context modifications can be stored into a variable as a \with object. They can be later inserted into another \with block.

context-mod-with.ly

[image of music]

Contexts of the same type can be nested.

context-nested-staffgroup.ly

[image of music]

\new can create a child of the same type and name as its parent. PASS should appear in the left margin.

context-new-child-same-name.ly

[image of music]

\new can create a sibling of an existing context with the same type and name. The instrument name should be PASS.

context-new-sibling-same-name.ly

[image of music]

Let ly:context-output-def access some output variables from inside a \applyContext expression.

context-output-def.ly

[image of music]

ly:context-property works on a deprecated context property. Odd-numbered measures should be marked with circles and even-numbered measures should be marked with boxes.

context-property-deprecated-scheme-get.ly

[image of music]

ly:context-set-property! works on a deprecated context property. The output should be a single measure with a B note.

context-property-deprecated-scheme-set.ly

[image of music]

ly:context-unset-property works on a deprecated context property. The output should be a single measure with a B note.

context-property-deprecated-scheme-unset.ly

[image of music]

ly:context-property-where-defined works on a deprecated context property. A coda sign should appear at the start of measure 2.

context-property-deprecated-scheme-where-defined.ly

[image of music]

\once \set works on a deprecated context property. The output should be a single measure with a B note.

context-property-deprecated-set-once.ly

[image of music]

\set works on a deprecated context property. The output should be a single measure with a B note.

context-property-deprecated-set.ly

[image of music]

\once \unset works on a deprecated context property. The output should have three bar lines: the middle line should be normal and the outer lines should be dotted.

context-property-deprecated-unset-once.ly

[image of music]

\unset works on a deprecated context property. The output should be a single measure with a B note.

context-property-deprecated-unset.ly

[image of music]

\pushContextProperty and \popContextProperty are two new commands for manipulating context properties. The first one pushes the current value to a stack and sets a new value, while the second one pops off the value from the stack and uses it to restore the previous value.

context-property-stack.ly

[image of music]

It is possible to define contexts that, when instantiated, take the normal place of Score.

This test should show a score with proportional notation and bigger note heads.

context-score-level.ly

[image of music]

Using \contextStringTuning does not break compiling.

context-string-tuning.ly

[image of music]

Test for cross-staff beams. Three issues are covered. All stems, beams, and note heads should be positioned correctly and there should be no programming errors.

cross-staff-beams.ly

[image of music]

Test for cross-staff stems. We check for properly connected chords, triplets, and auto-beamed beams correctly ended.

cross-staff-stems.ly

[image of music]

Cue clefs can be printed after a bar line.

cue-clef-after-barline.ly

[image of music]

Clefs for cue notes at the start of a score should print the standard clef plus a small cue clef after the time/key signature.

cue-clef-begin-of-score.ly

[image of music]

Clefs for cue notes should not influence the printed key signature.

cue-clef-keysignature.ly

[image of music]

Cue clefs can be printed manually.

cue-clef-manually.ly

[image of music]

Clefs for cue notes and line breaks. If the cue notes start in a new line, the cue clef should not be printed at the end of the previous line. Similarly, an end clef for cue notes ending at a line break should only be printed at the end of the line.

Cue notes going over a line break should print the standard clef on the new line plus an additional cue clef after the time/key signature.

cue-clef-new-line.ly

[image of music]

Optional transposition for clefs for cue notes is supported by using parentheses or brackets around the transposition number.

cue-clef-transposition-optional.ly

[image of music]

Transposition for clefs for cue notes.

cue-clef-transposition.ly

[image of music]

Clefs for cue notes: Print a cue clef at the begin of the cue notes and a canceling clef after the cue notes.

cue-clef.ly

[image of music]

Custos_engraver accepts (and ignores) unpitched notes.

custos-unpitched.ly

[image of music]

Custodes may be engraved in various styles.

custos.ly

[image of music]

Muted notes (also called dead notes) are supported within normal staves and tablature. They are printed correctly, even if another font for TabNoteHead is used.

dead-notes.ly

[image of music]

Cyclic dependencies are detected and warned about. When the debug-property-callbacks option is set, a backtrace is printed with the warning.

debug-property-callbacks.ly

[image of music]

Tests define-event-function by creating a trivial function converting a markup into a dynamic script post-event. As opposed to music functions, a direction indicator is not required.

define-event-function.ly

[image of music]

The VerticalAxisGroup.remove-layer property can be used for typesetting temporary divisi staves where the switch to split staves is done only at line breaks such that all complex passages are rendered in separate staves.

divisi-staves.ly

[image of music]

This test exercises ancient divisions (divisiones) with settings that are overridden in various built-in Staff contexts. Each Staff is in a separate \score.

divisiones-staff-override-alone.ly

[image of music]

By default, GregorianTranscriptionStaff creates BarLine grobs for \divisio… commands, but \EnableGregorianDivisiones makes it create Divisio grobs like the ancient-notation staves.

divisiones-staff-override-gregorian-transcription-style.ly

[image of music]

This test exercises ancient divisions (divisiones) with settings that are overridden in various built-in Staff contexts. All staves are in one StaffGroup.

divisiones-staff-override-grouped.ly

[image of music]

This test exercises semantic divisions with settings that are overridden in various built-in Staff contexts. Each Staff is in a separate \score.

divisions-staff-override-alone.ly

[image of music]

By default, GregorianTranscriptionStaff creates BarLine grobs for semantic division commands, but \EnableGregorianDivisiones makes it create Divisio grobs like the ancient-notation staves.

divisions-staff-override-gregorian-transcription-style.ly

[image of music]

This test exercises semantic divisions with settings that are overridden in various built-in Staff contexts. All staves are in one StaffGroup.

divisions-staff-override-grouped.ly

[image of music]

\cadenzaOn should not confuse the dodecaphonic-no-repeat accidental style. In this test, the second C should have a printed accidental since it is not immediately repeated.

dodecaphonic-no-repeat-cadenza.ly

[image of music]

Partials do not confuse the dodecaphonic-no-repeat accidental style. In this test, the second C should have a printed accidental since it is not immediately repeated.

dodecaphonic-no-repeat-partial.ly

[image of music]

Dot Columns are engraved in the Staff by default, enabling dots to move vertically to make room for dots from another voice. If Dot_column_engraver is moved to Voice, separate dot columns are engraved, and these dots avoid notes in other voices.

dot-column-engraver.ly

[image of music]

Dots and note-heads should not collide.

dot-column-note-collision.ly

[image of music]

Dot columns do not trigger beam slanting too early. This input should compile with no programming error message, and the dots should be correctly placed on their rests.

dot-column-rest-collision.ly

[image of music]

Dot columns should not trigger vertical spacing before line breaking. If the regtest issues a programming_error saying that vertical spacing has been called before line breaking, it has failed.

dot-column-vertical-positioning.ly

[image of music]

The dot-count property for Dots can be modified by the user.

dot-dot-count-override.ly

[image of music]

Dots move to the right when a collision with the (up)flag happens.

dot-flag-collision.ly

[image of music]

Dotted rests connected with beams do not trigger premature beam calculations. In this case, the beam should be sloped, and there should be no programming_error() warnings.

dot-rest-beam-trigger.ly

[image of music]

The dots on a dotted rest are correctly accounted for in horizontal spacing.

dot-rest-horizontal-spacing.ly

[image of music]

in collisions, the dots of outer voices avoid stems and flags of the inner voices.

dot-up-voice-collision.ly

[image of music]

Both noteheads and rests can have dots. Augmentation dots should never be printed on a staff line, but rather be shifted vertically. They should go up, but in case of multiple parts, the down stems have down shifted dots. In case of chords, all dots should be in a column. The dots follow the shift of rests when avoiding collisions.

The priorities to print the dots are (ranked in importance):

  • keeping dots off staff lines,
  • keeping dots close to their note heads,
  • moving dots in the direction specified by the voice,
  • moving dots up.

dots.ly

[image of music]

Pitches for drums may have a defined articulation sign. This test checks the predefined drum styles and prints only drum pitches with an articulation sign.

drum-scripts.ly

[image of music]

In drum notation, there is a special clef symbol, drums are placed to their own staff positions and have note heads according to the drum, an extra symbol may be attached to the drum, and the number of lines may be restricted.

drums.ly

[image of music]

The compression factor of a duration identifier is correctly accounted for by the parser.

duration-identifier-compressed.ly

[image of music]

Duration_line_engraver works nicely with \partCombine.

If \partCombine combines notes to chords both note heads get a DurationLine.

duration-line-and-partCombine.ly

[image of music]

At line break a broken DurationLine, like Glissando, avoids items with break-aligned-interface, like KeySignature, BreathingSign etc., but not items with the break-alignable-interface, like TextMark, MetronomeMark, etc..

duration-line-at-line-break.ly

[image of music]

A DurationLine grob may end with a special behavior. Currently available are hooks (with settable direction) and arrows.

duration-line-end-items.ly

[image of music]

Duration lines are placed vertically correct for non-default staff sizes and all styles.

duration-line-magnified-staff.ly

[image of music]

Duration lines work across staff changes.

duration-line-staff-change.ly

[image of music]

A DurationLine grob may start/end at NoteHead, Rest, skip-event (if forced, otherwise skips are passed), NoteHeads of EventChord or at an entire NoteColumn. Start/end at MultiMeasureRest is only basically supported.

It stops automatically if the Voice pauses, i.e., no rhythmical events happen for some time, and at end of score.

Avoids Dots (if forced), Accidentals and Arpeggio (per changeable default).

duration-line-start-stop.ly

[image of music]

Several styles for the DurationLine grob are available: 'beam, 'line, 'dashed-line, 'dotted-line, 'zigzag, 'trill and 'none.

duration-line-styles.ly

[image of music]

The visible thickness of a duration line is adjusted properly according to the staff space for all styles, like for long compressed MultiMeasureRest. Changes in StaffSymbol.thickness are disregarded.

duration-line-thickness-staff-sizes.ly

[image of music]

DurationLine should pass a tied NoteHead, but a previous Tie should not be taken into account. In this test the DurationLine, starting at the third note of each line, should end before the fourth note of said line.

duration-line-tie.ly

[image of music]

Duration multipliers can be specified as scheme expressions, either as rationals or as a moment.

duration-multiplier-scheme.ly

[image of music]

If a dynamic has an explicit direction that differs from the dynamic line spanner’s direction, automatically break the dynamic line spanner.

dynamics-alignment-autobreak.ly

[image of music]

\breakDynamicSpan shall also work if a dynamic spanner crosses a line break.

dynamics-alignment-breaker-linebreak.ly

[image of music]

\breakDynamicSpan work whether it is placed together with the start or the end of a spanner. Both lines should be identical.

dynamics-alignment-breaker-order.ly

[image of music]

\breakDynamicSpan shall only have an effect on the current spanner, not on subsequent spanners.

dynamics-alignment-breaker-subsequent-spanner.ly

[image of music]

Hairpins, DynamicTextSpanners and dynamics can be positioned independently using \breakDynamicSpan, which causes the alignment spanner to end prematurely.

dynamics-alignment-breaker.ly

[image of music]

Setting the style of a DynamicTextSpanner to 'none to hide the line altogether should also work over line breaks.

dynamics-alignment-no-line-linebreak.ly

[image of music]

If the line for a DynamicTextSpanner is hidden, the alignment spanner for dynamics is ended early. This allows consecutive dynamics to be unlinked.

dynamics-alignment-no-line.ly

[image of music]

Cross-staff Dynamic does not trigger a cyclic dependency for direction look-up.

dynamics-avoid-cross-staff-stem.ly

[image of music]

When a hairpin is broken, the broken parts should be open at the ‘breaking point’.

dynamics-broken-hairpin.ly

[image of music]

Text spanners work in the Dynamics context.

dynamics-context-textspan.ly

[image of music]

Postfix functions for custom crescendo text spanners. The spanners should start on the first note of the measure. One has to use -\mycresc, otherwise the spanner start will rather be assigned to the next note.

dynamics-custom-text-spanner-postfix.ly

[image of music]

An empty Dynamics context does not confuse the spacing.

dynamics-empty.ly

[image of music]

Dynamic letters are kerned, and their weight matches that of the hairpin signs. The dynamic scripts should be horizontally centered on the note head. Scripts that should appear closer to the note head (staccato, accent) are reckoned with.

dynamics-glyphs.ly

[image of music]

By default hairpins extend to the extremes of the bound if there is no adjacent hairpin or dynamic text. A hairpin may instead extend to the LEFT, CENTER or RIGHT of NoteColumn grobs by overriding property endpoint-alignments, which is a pair of numbers representing the left and right ends of the hairpin. endpoint-alignments are expected to be directions (either -1, 0 or 1). Other values will be transformed with a warning. The right end of a hairpin terminating at a rest is not affected, always ending at the left edge of the rest.

dynamics-hairpin-endpoint-alignment.ly

[image of music]

Hairpins extend to the extremes of the bound if there is no adjacent hairpin or dynamic-text. If there is, the hairpin extends to the center of the column or the bound of the text respectively.

dynamics-hairpin-length.ly

[image of music]

Dynamics appear below or above the staff. If multiple dynamics are linked with (de)crescendi, they should be on the same line. Isolated dynamics may be forced up or down.

dynamics-line.ly

[image of music]

DynamicText, DynamicLineSpanner, and Hairpin do not have outside-staff-priority in Dynamics contexts. This allows grobs with outside-staff-priority set to be positioned above and below them.

dynamics-outside-staff-priority.ly

[image of music]

Text dynamics are positioned correctly on rests, i.e., centered on the parent object.

dynamics-rest-positioning.ly

[image of music]

The X-offset of DynamicText grobs in a Dynamics context should be averaged over the center of NoteColumn grobs in the DynamicText’s PaperColumn.

dynamics-text-dynamics-context.ly

[image of music]

The left text of a DynamicTextSpanner is left-aligned to its anchor note.

dynamics-text-left-text-alignment.ly

[image of music]

The space between an absolute dynamic and a dynamic text span can be changed using 'right-padding.

dynamics-text-right-padding.ly

[image of music]

left attach dir for text crescendi starting on an absolute dynamic is changed, so cresc. and the absolute dynamic don’t overstrike.

dynamics-text-spanner-abs-dynamic.ly

[image of music]

The 2nd half of the cresc. stays at a reasonable distance from the notes.

dynamics-text-spanner-padding.ly

[image of music]

The \cresc, \dim and \decresc spanners are now postfix operators and produce one text spanner. Defining custom spanners is also easy. Hairpin and text crescendi can be easily mixed. \< and \> produce hairpins by default, \cresc etc. produce text spanners by default.

dynamics-text-spanner-postfix.ly

[image of music]

Crescendi may start off-notes, however, they should not collapse into flat lines.

dynamics-unbound-hairpin.ly

[image of music]

Accidentals are positioned correctly when using Easy notation.

easy-notation-accidentals.ly

[image of music]

Easy noteheads should be scalable in size, like in grace notes. This works with \magnifyStaff and layout-set-staff-size as well.

easy-notation-size.ly

[image of music]

Easy-notation (or Ez-notation) prints names in note heads. You also get ledger lines, of course.

easy-notation.ly

[image of music]

PostScript code can be directly inserted inside a \markup block.

embedded-postscript.ly

[image of music]

Strings and comments inside of #{…#} should not be confiusing to the embedded LilyPond parser. If this test succeeds, three notes with (#), ($), and (%) underneath will get displayed here.

embedded-strings-comments.ly

[image of music]

The Emmentaler font contains kerning for many number pairs.

emmentaler-number-kerning.ly

[image of music]

Empty chords accept articulations, occupy no time, and leave the current duration unchanged.

empty-chord.ly

[image of music]

The functions ly:engraver-make-item and ly:engraver-make-spanner are similar to ly:engraver-make-grob. They are useful when the grob definition does not mandate a particular grob class.

engraver-make-item-spanner.ly

[image of music]

An episema can be typeset over a single neume or a melisma. Its position is quantized between staff lines.

episema.ly

[image of music]

Music events can be extracted from a score with event listeners.

event-listener-output.ly

[image of music]

A mode switching command like \lyricsto will ‘pop state’ when seeing the lookahead token \time, a music function, after its non-delimited argument. This must not cause the extra token parsing state for the music function to disappear.

extratoken.ly

[image of music]

Fermatas have an appropriate distance to dots, note heads and other articulations.

fermata-dot-position.ly

[image of music]

Trills and trill spanners should be below fermatas. Fermatas should be below ottava spanners.

fermata-outside-staff-priority.ly

[image of music]

Fermatas over multimeasure rests are positioned as over normal rests.

fermata-rest-position.ly

[image of music]

LilyPond creates hairpins found in Ferneyhough scores. Flared hairpins may print circled tips.

ferneyhough-hairpins.ly

[image of music]

Bass figures can carry alterations, which may also be bracketed.

figured-bass-alteration.ly

[image of music]

Pairs of congruent figured bass extender lines are vertically centered if figuredBassCenterContinuations is set to true.

figured-bass-continuation-center.ly

[image of music]

A figured bass continuation line after an empty bass figure has a correct vertical position.

figured-bass-continuation-empty.ly

[image of music]

Figured bass extender for figures of different width (e.g., with alteration or two-digit figures) should still stop at the same position.

figured-bass-continuation-end-position.ly

[image of music]

By adorning a bass figure with \!, an extender may be forbidden.

figured-bass-continuation-forbid.ly

[image of music]

Figured bass extender lines shall be broken when a figure has a different alteration, augmentation, or diminishment.

figured-bass-continuation-modifiers.ly

[image of music]

Figured bass extender lines run between repeated bass figures. They are switched on with useBassFigureExtenders.

figured-bass-continuation.ly

[image of music]

Bass figures and extenders shall also work correctly if the figure has a different duration than the bass note. In particular, if a timestep does not have a new figure (because the old figure still goes on), extenders should be drawn and not be reset.

figured-bass-durations.ly

[image of music]

Bass figures may be empty and still take up space.

figured-bass-empty-figures.ly

[image of music]

When using extender lines in figured bass, markup objects should be treated like ordinary figures and work correctly with extender lines.

Extenders should only be used if the markup is really identical.

figured-bass-extenders-markup.ly

[image of music]

Figured bass extenders do not distort vertical spacing.

figured-bass-extenders-spacing.ly

[image of music]

When figures appear inside a voice, ignoreFiguredBassRest causes all figures on rests to be discarded and all spanners ended. If set to #f, figures on rests are printed.

figured-bass-ignore-rest.ly

[image of music]

Implicit bass figures are not printed, but they do get extenders.

figured-bass-implicit.ly

[image of music]

Bass figures with more than a single digit can be positioned differently.

figured-bass-large-numbers.ly

[image of music]

Figured bass in a Staff context doesn’t collide with articulations.

figured-bass-script.ly

[image of music]

Figured bass supports numbers with slashes through them.

figured-bass-slashed-numbers.ly

[image of music]

Figured bass can also be added to Staff context directly. In that case, the figures must be entered with \figuremode and be directed to an existing Staff context.

Since these engravers are on Staff level, properties controlling figured bass should be set in Staff context.

figured-bass-staff.ly

[image of music]

Figured bass is created by the FiguredBass context, which responds to figured bass and rest events.

You can also enter markup strings; the vertical alignment may also be tuned.

figured-bass.ly

[image of music]

The fill-line markup command should align texts in columns. For example, the characters in the center should form one column.

fill-line-test.ly

[image of music]

Context modification via \with filters translators of the wrong type: performers for an Engraver_group and engravers for a Performer_group. In this test, the Instrument_name_engraver is added to a StaffGroup, but does not affect midi output, since it is filtered out.

filter-translators.ly

[image of music]

\fine places a performance instruction below all staves and at end-of-line at a break, except at the written end of the music. The context property fineText controls the text.

fine.ly

[image of music]

Scripts left of a chord avoid accidentals.

finger-chords-accidental.ly

[image of music]

Scripts right of a chord avoid dots.

finger-chords-dot.ly

[image of music]

Ordering of the fingerings depends on vertical ordering of the notes, and is independent of up/down direction.

finger-chords-order.ly

[image of music]

It is possible to associate fingerings uniquely with notes. This makes it possible to add horizontal fingerings to notes. Fingering defaults to not clearing flags and stems unless there is a collision or a beam.

finger-chords.ly

[image of music]

The FingerGlideSpanner is able to connect non-matching Fingerings using the id property. In the test, equally colored fingers should be connected.

finger-glide-spanner-id.ly

[image of music]

The FingerGlideSpanner grob prints nicely for all styles if there are line breaks. For the styles stub-right, stub-left and stub-right the printed line is intentionally shorter.

finger-glide-spanner-line-break-styles.ly

[image of music]

The FingerGlideSpanner is not confused by multiple fingerings.

finger-glide-spanner-multiple-fingerings.ly

[image of music]

Nested FingerGlideSpanner grobs work. A breaking line does not disturb the printing, the part after the break continues with the same angle.

finger-glide-spanner-nested-line-break.ly

[image of music]

The FingerGlideSpanner may be printed in several styles.

finger-glide-spanner-styles.ly

[image of music]

The FingerCodeSpanner may connect Fingering, StrokeFinger and StringNumber grobs.

finger-glide-spanner.ly

[image of music]

Fingering grobs created by the New_fingering_engraver (i.e., fingerings entered inside of <>) with fingeringOrientations set to up or down avoid accidentals of displaced notes that might get into the way in chords containing adjacent notes (seconds) or unison notes.

With \override Fingering.X-align-on-main-noteheads = ##t, the fingerings oriented up and down are arranged in a straight column aligned on the noteheads on the “correct” side of the stem.

fingering-adjacent-note-chord-new.ly

[image of music]

Fingering grobs created by the Fingering_engraver (i.e., fingerings entered outside of <>) above or below chords containing adjacent notes (seconds) or unison notes should be aligned on the main noteheads, i.e., on the noteheads that are on the “correct” side of the stem.

Incidentally, this also avoids collisions with accidentals.

fingering-adjacent-note-chord.ly

[image of music]

Horizontally-offset Fingerings align along the Y axis when they are within FingeringColumn.snap-radius of each other.

fingering-column-snap-radius.ly

[image of music]

Horizontal Fingering grobs that collide do not intersect. Non-intersecting Fingering grobs are left alone. This is managed by the FingeringColumn grob.

fingering-column.ly

[image of music]

Fingerings work correctly with cross-staff beams.

fingering-cross-staff.ly

[image of music]

Fingering directions in directed and undirected contexts.

fingering-directions.ly

[image of music]

Fingerings don’t segfault when their stencil is set to ##f.

fingering-no-stencil.ly

[image of music]

If a Fingering grob is left- or right-positioned, the Y-offset property is taken relative to the vertical position of its X-parent (i.e., its associated note head).

fingering-y-offset-new.ly

[image of music]

Automatic fingering tries to put fingering instructions next to noteheads.

fingering.ly

[image of music]

Stems reach correct begin points of merged noteheads.

flag-stem-begin-position.ly

[image of music]

\flageolet draws a small circle on top of the note when a natural harmonic is needed.

flageolet.ly

[image of music]

Default flag styles: '(), 'mensural, 'stacked, and 'no-flag.

Compare all three methods to print them: (1) C++ default implementation, (2) Scheme implementation using the 'style grob property, and (3) setting the 'flag property explicitly to the desired Scheme function.

All three systems should be absolutely identical.

flags-default.ly

[image of music]

The ’stencil property of the Flag grob can be set to a custom scheme function to generate the glyph for the flag.

flags-in-scheme.ly

[image of music]

Straight flags scale according to layout-set-staff-size in MetronomeMark, TextScript and music.

flags-straight-layout-staff-size.ly

[image of music]

Straight flags scale properly at different staff sizes for TextScript and music.

The test uses extreme staff size values, scaled to approximately the same size for better comparison.

flags-straight-staff-size.ly

[image of music]

Flags can be drawn straight in the style used by Stockhausen and Boulez.

flags-straight-stockhausen-boulez.ly

[image of music]

Straight flag styles.

flags-straight.ly

[image of music]

Stencils can be flipped horizontally or vertically within their bounding box using flip-stencil.

flip-stencil.ly

[image of music]

The line-spanners connects to the Y position of the note on the next line. When put across line breaks, only the part before the line break is printed.

follow-voice-break.ly

[image of music]

The voice follower is not confused when set for consecutive sets of staff switches.

follow-voice-consecutive.ly

[image of music]

TM and No should not be changed into trademark/number symbols. This may happen with incorrect font versions.

font-bogus-ligature.ly

[image of music]

The default font families for text can be overridden.

font-family-override.ly

[image of music]

Exercise font features. Requires a font that supports the features. This ensures no errors using the interface.

font-features.ly

[image of music]

Text gets kerned if the used font supports that.

font-kern.ly

[image of music]

External fonts may be used without being installed on the operating system, by loading either a specific font file or a directory that contains font files. In this example two logos (’GPL’ and ’GFDL’) should be printed, rather than letter glyphs.

font-name-add-files.ly

[image of music]

Setting the font-name property does not change the font size. The two strings below should be concatenated and have the same font size.

Note that ‘the same font size’ is related to what lilypond reports on the console if in verbose mode (3.865234375 units for this regression test). If you actually look at the two fonts the optical size differs enormously.

font-name-font-size.ly

[image of music]

Other fonts can be used by setting font-name for the appropriate object. The string should be a Pango font description without size specification.

font-name.ly

[image of music]

This is an example of automatic footnote numbering where the number is reset on each page. It uses the symbol-footnotes numbering function, which assigns the symbols *, †, ‡, § and ¶ to successive footnotes, doubling up on the symbol after five footnotes have been reached.

footnote-auto-numbering-page-reset.ly

[image of music]

This regtest makes sure that footnote numbers are laid out in the correct vertical order.

footnote-auto-numbering-vertical-order.ly

[image of music]

This is an example of automatic footnote numbering where the number is not reset on each page. It uses the default numbering function, which assigns numbers starting at 1 to successive footnotes.

footnote-auto-numbering.ly

[image of music]

Balloons and footnotes on multi-measure rest numbers and percent repeat counters are correctly placed.

footnote-balloon-on-counter.ly

[image of music]

Automatic beams may receive footnotes.

footnote-beam.ly

[image of music]

With grobs that have break visibility, footnotes will automatically take the break visibility of the grob being footnoted. This behavior can be overridden.

footnote-break-visibility.ly

[image of music]

Footnotes work on cross-staff grobs.

footnote-cross-staff.ly

[image of music]

The padding between a footnote and the footer can be tweaked.

footnote-footer-padding.ly

[image of music]

Lyrics may receive footnotes.

footnote-lyrics.ly

[image of music]

Multi-measure rests may receive footnotes.

footnote-mmrest.ly

[image of music]

Footnotes are annotated at the correct place, and the annotation goes to the correct page.

footnote-spanner.ly

[image of music]

Footnotes on volta brackets also work

footnote-volta-spanner.ly

[image of music]

Lilypond does footnotes.

footnote.ly

[image of music]

forbidBreakBetweenBarLines controls whether Bar_engraver forbids line breaks where there is no bar line. The output should have a break in the middle of a measure.

forbid-break-between-bar-lines.ly

[image of music]

FretBoards should be aligned in the Y direction at the fret-zero, string 1 intersection.

fret-board-alignment.ly

[image of music]

Frets can be assigned automatically. The results will be best when one string number is indicated in advance

fret-boards.ly

[image of music]

Fret diagrams of different orientation should share a common origin of the topmost fret or string.

fret-diagram-origins.ly

[image of music]

A capo indicator can be added with a fret-diagram-verbose string, and its thickness can be changed.

fret-diagrams-capo.ly

[image of music]

Dots in fret diagrams may be colored as well as the entire fret diagram. Not explicitely colored dots take the color from TextScript grob or from with-color. Otherwise the specified color is preserved. Parentheses take their color from the dot, if default-paren-color is used they take their color from the overall color. Works for inverted dots as well.

fret-diagrams-dot-color.ly

[image of music]

Dots indicating fingerings can be changed in location, size, and coloring. It is possible to parenthesize a single dot. The color of the paranthesis may be taken from dot or default. A possible collision between parathesis and fret-label- indication can be resolved by an override for fret-label-horizontal-offset in fret-diagram-details.

fret-diagrams-dots.ly

[image of music]

Finger labels can be added, either in dots or below strings. Dot color can be changed globally or on a per-dot basis, and fingering label font size can be adjusted.

fret-diagrams-fingering.ly

[image of music]

The label for the lowest fret can be changed in location, size, and number type.

fret-diagrams-fret-label.ly

[image of music]

Fret diagrams can be presented in landscape mode.

fret-diagrams-landscape.ly

[image of music]

Fret-diagrams may be printed left-handed

fret-diagrams-left-handed.ly

[image of music]

Fret diagrams can be presented in landscape mode.

fret-diagrams-opposing-landscape.ly

[image of music]

Fret diagrams can be scaled using the size property. Also, scaling the distance between the frets and/or strings is possible with the properties fret-distance and/or string-distance of fret-diagram-details. The position and size of first fret label, mute/open signs, fingers, relative to the diagram grid, shall be the same in all cases.

fret-diagrams-size.ly

[image of music]

Number of frets and number of strings can be changed from the defaults.

fret-diagrams-string-frets.ly

[image of music]

String thickness can be changed, and diagrams can have variable string thickness. The thick zero-fret is adjusted accordingly for changed size, fret-diagram-details.string-thickness-factor and fret-diagram-details.top-fret-thickness. There should be no visible gap inside the red circle.

fret-diagrams-string-thickness.ly

[image of music]

The size, spacing, and symbols used to indicate open and muted strings can be changed.

fret-diagrams-xo-label.ly

[image of music]

FretBoards can be set to display only when the chord changes or at the beginning of a new line.

fretboard-chordchanges.ly

[image of music]

Markups can be put into the dots of a fret-diagram. Those markups are scaled automatically to fit into the dots.

fretdiagram-markup-in-dots.ly

[image of music]

Fermata over full-measure rests should invert when below and be closer to the staff than other articulations.

full-measure-rest-fermata.ly

[image of music]

This file tests various Scheme utility functions.

general-scheme-bindings.ly

[image of music]

As a last resort, the placement of grobs can be adjusted manually, by setting the extra-offset of a grob.

generic-output-property.ly

[image of music]

Glissandi stop before hitting accidentals. Chord glissandi stop at the same horizontal position and have the same slope, they do not cross.

glissando-accidental.ly

[image of music]

When broken, glissandi can span multiple lines.

glissando-broken-multiple.ly

[image of music]

Broken glissandi anticipate the pitch on the next line.

glissando-broken-unkilled.ly

[image of music]

If broken, Glissandi anticipate on the pitch of the next line.

glissando-broken.ly

[image of music]

A glissando between chords should not interfere with line breaks. In this case, the music should be in two lines and there should be no warning messages issued. Also, the glissando should be printed.

glissando-chord-linebreak.ly

[image of music]

LilyPond typesets glissandi between chords.

glissando-chord.ly

[image of music]

Lilypond prints consecutive glissandi.

glissando-consecutive.ly

[image of music]

Broken cross-staff glissandi have acceptable slopes when one staff is removed.

glissando-cross-staff-broken-remove-empty.ly

[image of music]

Broken cross-staff glissandi can span more than two systems.

glissando-cross-staff-broken-several-systems.ly

[image of music]

Cross-staff glissandi have acceptable slopes when they cross line breaks.

glissando-cross-staff-broken.ly

[image of music]

Broken cross-staff glissandi have acceptable slopes when one staff is removed.

glissando-cross-staff-staff-absent.ly

[image of music]

Cross staff glissandi reach their endpoints correctly.

glissando-cross-staff.ly

[image of music]

Glissandi begin after dots by default. This behavior may be changed by overriding the start-at-dot property.

glissando-dots.ly

[image of music]

Individual glissandi within a chord can be tweaked.

glissando-index.ly

[image of music]

Glissandi are not broken. Output of this test is expected to run off the page.

glissando-no-break.ly

[image of music]

NoteColumn grobs can be skipped over by glissandi.

glissando-skip.ly

[image of music]

stencil-align-dir-y also works on glissandi.

glissando-stencil-align-dir-y.ly

[image of music]

Between notes, there may be simple glissando lines. Here, the first two glissandi are not consecutive.

The engraver does no time-keeping, so it involves some trickery to get << { s8 s8 s4 } { c4 \gliss d4 } >> working correctly.

glissando.ly

[image of music]

A grace in the first alternative does not cause the beaming to go awry in subsequent material

grace-alternative.ly

[image of music]

A separate ‘Grace_auto_beam_engraver’ initiates autobeaming at the start of each \grace command.

grace-auto-beam-engraver.ly

[image of music]

The autobeamer is not confused by grace notes.

grace-auto-beam.ly

[image of music]

Bar line should come before the grace note.

grace-bar-line.ly

[image of music]

Grace notes do tricky things with timing. If a measure starts with a grace note, the measure does not start at 0, but earlier. Nevertheless, lily should not get confused. For example, line breaks should be possible at grace notes, and the bar number should be printed correctly.

grace-bar-number.ly

[image of music]

Grace beams and normal beams may occur simultaneously. Unbeamed grace notes are not put into normal beams.

grace-beam.ly

[image of music]

The \voiceOne setting is retained after finishing the grace section.

grace-direction-polyphony.ly

[image of music]

Grace notes at the end of an expression don’t cause crashes.

grace-end-expression.ly

[image of music]

Grace notes after the last note do not confuse the timing code.

grace-end.ly

[image of music]

Grace-timed elements in sequence line up before the next main note in the obvious way.

grace-multiple.ly

[image of music]

startGraceMusic and stopGraceMusic may be overridden to change the properties of grace notes. In this test, the stems of the grace notes point down.

grace-music-override.ly

[image of music]

Grace code should not be confused by nested sequential music containing grace notes; practically speaking, this means that the end-bar and measure bar coincide in this example.

grace-nest1.ly

[image of music]

Grace code should not be confused by nested sequential music containing grace notes; practically speaking, this means that the end-bar and measure bar coincide in this example.

grace-nest2.ly

[image of music]

In nested syntax, graces are still properly handled.

grace-nest3.ly

[image of music]

Also in the nested syntax here, grace notes appear rightly.

grace-nest4.ly

[image of music]

Graces notes may have the same duration as the main note.

grace-nest5.ly

[image of music]

Grace notes may be put in a partCombiner.

grace-part-combine.ly

[image of music]

A \partial may be combined with a \grace.

grace-partial.ly

[image of music]

Create grace notes with slashed stem, but no slur. That can be used when the grace note is tied to the next note.

grace-slashed-no-slur.ly

[image of music]

Stripped version of trip.ly. Staves should be of correct length.

grace-staff-length.ly

[image of music]

The various kinds of grace music are similar in how they create contexts. In this test, each grace note should create a new staff.

grace-start-context.ly

[image of music]

Pieces may begin with grace notes.

grace-start.ly

[image of music]

Stem lengths for grace notes should be shorter than normal notes, if possible. They should never be longer, even if that would lead to beam quanting problems.

grace-stem-length.ly

[image of music]

Here startGraceMusic should set no-stem-extend to true; the two grace beams should be the same here.

grace-stems.ly

[image of music]

Grace notes in different voices/staves are synchronized.

grace-sync.ly

[image of music]

There are three different kinds of grace types: the base grace switches to smaller type, the appoggiatura inserts also a slur, and the acciaccatura inserts a slur and slashes the stem.

grace-types.ly

[image of music]

When grace notes are entered with unfolded repeats, line breaks take place before grace notes.

grace-unfold-repeat.ly

[image of music]

A volta repeat may begin with a grace. Consecutive ending and starting repeat bars are merged into one :..:.

grace-volta-repeat-merge-barline.ly

[image of music]

Repeated music can start with grace notes. Bar checks preceding the grace notes do not cause synchronization effects.

grace-volta-repeat.ly

[image of music]

You can have beams, notes, chords, stems etc. within a \grace section. If there are tuplets, the grace notes will not be under the brace.

Main note scripts do not end up on the grace note.

grace.ly

[image of music]

The graphviz feature draws dependency graphs for grob properties.

graphviz.ly

[image of music]

GregorianTranscriptionStaff does not print ligatures.

gregorian-transcription-no-ligatures.ly

[image of music]

With grid lines, vertical lines can be drawn between staves synchronized with the notes.

grid-lines.ly

[image of music]

With the full form of the \tweak function, individual grobs that are indirectly caused by events may be tuned.

grob-indirect-tweak.ly

[image of music]

ly:grob-object supports a third optional parameter, the fallback value to use when the property is undefined in the grob. This test should print ’Test OK’ twice.

grob-object-fallback.ly

[image of music]

With the \tweak function, individual grobs that are directly caused by events may be tuned directly.

grob-tweak.ly

[image of music]

Hairpins in Dynamics contexts do not collide with arpeggios.

hairpin-arpeggio.ly

[image of music]

If a hairpin ends on the first note of a new staff, we do not print that ending. But on the previous line, this hairpin should not be left open, and should end at the bar line.

hairpin-barline-break.ly

[image of music]

Hairpins can have circled tips. A decrescendo del niente followed by a crescendo al niente should only print one circle. If a decrescendo ends at first note of a new line the circle is printed at the end of the previous line or in the new line, depending on the setting of after-line-breaking.

hairpin-circled.ly

[image of music]

Broken hairpins are not printed too high after treble clefs.

hairpin-clef.ly

[image of music]

Hairpin crescendi may be dashed.

hairpin-dashed.ly

[image of music]

Hairpin dynamics start under notes if there are no text-dynamics. If there are text dynamics, the hairpin does not run into them.

hairpin-ending.ly

[image of music]

Broken hairpins are not printed too high after key signatures.

hairpin-key-signature.ly

[image of music]

Bound padding for hairpins also applies before following DynamicTextSpanner grobs. In this case, bound-padding is not scaled down.

hairpin-neighboring-span-dynamics.ly

[image of music]

The shorten-pair property works with circled-tip hairpins. When two hairpins share a circle, the adjoining ends are not moved. The same holds, if flared-hairpin is used to get hairpins in the style of Ferneyhough.

hairpin-shorten-pair-circled-tip.ly

[image of music]

The ends of hairpins may be offset with the shorten-pair property. Positive values offset ends to the right, negative values to the left.

hairpin-shorten-pair.ly

[image of music]

Hairpin grobs do not collide with SpanBar grobs. Hairpin grobs should, however, go to the end of a line when the SpanBar is not present.

hairpin-span-bar.ly

[image of music]

’to-barline is not confused by very long marks.

hairpin-to-barline-mark.ly

[image of music]

Hairpins whose end note is preceded by a bar line should end at that bar line.

hairpin-to-barline.ly

[image of music]

Hairpins end at the left edge of a rest.

hairpin-to-rest.ly

[image of music]

The halfopenvertical articulation is available.

halfopenvertical.ly

[image of music]

Staves in a PianoStaff remain alive as long as any of the staves has something interesting.

hara-kiri-alive-with.ly

[image of music]

Hara-kiri staves are suppressed if they are empty. This example really contains three drum staves, but as it progresses, empty ones are removed: this example has three staves, but some of them disappear: note how the 2nd line only has the bar number 2. (That the bar number is printed might be considered a bug, however, the scenario of all staves disappearing does not happen in practice.)

Any staff brackets and braces are removed, both in the single staff and no staff case.

hara-kiri-drumstaff.ly

[image of music]

Inserting the harakiri settings globally into the Staff context should not erase previous settings to the Staff context.

hara-kiri-keep-previous-settings.ly

[image of music]

Staves, RhythmicStaves, TabStaves and DrumStaves with percent repeats are not suppressed.

hara-kiri-percent-repeat.ly

[image of music]

Hara-kiri staves are suppressed if they are empty. This example really contains three rhythmic staves, but as it progresses, empty ones are removed: this example has three staves, but some of them disappear: note how the 2nd line only has the bar number 2. (That the bar number is printed might be considered a bug, however, the scenario of all staves disappearing does not happen in practice.)

Any staff brackets and braces are removed, both in the single staff and no staff case.

hara-kiri-rhythmicstaff.ly

[image of music]

Hara-kiri staves kill themselves if they are empty. This example really contains three staves, but as they progress, empty ones are removed: this example has three staves, but some of them disappear: note how the 2nd line only has the bar number 2. (That the bar number is printed might be considered a bug, however, the scenario of all staves disappearing does not happen in practice.)

Any staff brackets and braces are removed, both in the single staff and no staff case.

hara-kiri-staff.ly

[image of music]

stanza numbers remain, even on otherwise empty lyrics lines.

hara-kiri-stanza-number.ly

[image of music]

Hara-kiri staves are suppressed if they are empty. This example really contains three tab staves, but as it progresses, empty ones are removed: this example has three staves, but some of them disappear: note how the 2nd line only has the bar number 2. (That the bar number is printed might be considered a bug, however, the scenario of all staves disappearing does not happen in practice.)

hara-kiri-tabstaff.ly

[image of music]

The harp-pedal markup function does some sanity checks. All the diagrams here violate the standard (7 pedals with divider after third), so a warning is printed out, but they should still look okay.

harp-pedals-sanity-checks.ly

[image of music]

Harp pedals can be tweaked through the size, thickness and harp-pedal-details properties of TextScript.

harp-pedals-tweaking.ly

[image of music]

Basic harp diagram functionality, including circled pedal boxes. The third diagram uses an empty string, the third contains invalid characters. Both cases will create warnings, but should still not fail with an error.

harp-pedals.ly

[image of music]

A second book-level header block and headers nested in bookpart and score should not clear values from the first header block. This score should show composer, piece, subtitle and title.

header-book-multiple.ly

[image of music]

Changing the header fields in a book or a bookpart shall not have any effect on the global default values.

header-book-multiplescores.ly

[image of music]

A second bookpart-level header block shall retain previously set values from a first header block at the same or higher levels unless overriden.

header-bookpart-multiple.ly

[image of music]

Cyclic references in header fields should cause a warning, but not crash LilyPond with an endless loop

header-cyclic-reference.ly

[image of music]

A second score-level header block shall not entirely replace a first header block, but only update changed variables.

header-score-multiple.ly

[image of music]

Header blocks may appear before and after the actual music in a score.

header-score-reordered.ly

[image of music]

A second top-level header block shall not entirely replace a first header block, but only changed variables.

header-toplevel-multiple.ly

[image of music]

Using \override Beam.damping = #+inf.0 should always make beams horizontal. A threshold is implemented to avoid rounding errors that would cause non-horizontal beams otherwise.

Here, the beam should be horizontal.

horizontal-beams-damping.ly

[image of music]

Horizontal brackets connect over line breaks.

horizontal-bracket-break.ly

[image of music]

Text is parenthesized when analysis brackets cross line breaks.

horizontal-bracket-broken-texted.ly

[image of music]

Labels may be added to analysis brackets through the text property of the HorizontalBracketText object. Use of the weak command is necessary for assigning text uniquely to brackets beginning at the same moment. Text assignments reflect the usual nesting order of brackets.

horizontal-bracket-texted.ly

[image of music]

Horizontal brackets are created with the correct event-cause, ensuring tweaks are applied to the correct spanner.

horizontal-bracket-tweak.ly

[image of music]

Note grouping events are used to indicate where analysis brackets start and end.

horizontal-bracket.ly

[image of music]

Horizontal Script grobs are triggered by setting side-axis to X. This works with stand-alone notes and chords regardless of whether other scripts, fingerings etc are already present. The direction is taken from scriptDefinitions or from user settings. For convenience the short-cuts \atLeft and \atRight take care of setting side-axis and direction. Collisions with dots and accidentals are avoided.

horizontal-script.ly

[image of music]

Shows the id property of a grob being set. This should have no effect.

id.ly

[image of music]

Music variables may be structured into alists indexed by numbers or symbols.

identifier-alists.ly

[image of music]

Identifiers following a chordmode section are not interpreted as chordmode tokens. In the following snippet, the identifier ‘m’ is not interpreted by the lexer as a minor chord modifier.

identifier-following-chordmode.ly

[image of music]

Music identifiers containing arbitrary characters may be initialized using

"violin1" = { c''4 c'' c'' c'' }

and used as:

\new Voice { \"violin1" }

identifier-quoted.ly

[image of music]

test identifiers.

identifiers.ly

[image of music]

In-notes can be controlled via \paper variables.

in-note-configuration.ly

[image of music]

LilyPond does in-notes.

in-note.ly

[image of music]

Incipits can be printed using an InstrumentName grob. In the second line of the second score the InstrumentName grob should appear left-aligned.

incipit.ly

[image of music]

\include accepts a string-valued variable. The expected output is three quarter notes.

include-identifier.ly

[image of music]

ly:parser-include-string should include the current string like a file \include.

include-string.ly

[image of music]

Combine several kinds of stems in parallel voices.

incompatible-stem-warning.ly

[image of music]

\inherit-acceptability allows for one context def to be accepted wherever an existing one is.

inherit-acceptability.ly

[image of music]

The argument of \initialContextFrom is susceptible to modification by tags. The expected output is a single measure with “PASS” in the left margin.

initial-context-from-tags.ly

[image of music]

Alignment of lyrics, dynamics, textscripts and articulations attached to chords with suspended notes doesn’t depend on input order. All these items are aligned on the "main" notehead (the one at the end of the stem).

input-order-alignment.ly

[image of music]

The Voice.instrumentCueName property generates instrument names for cue notes. It can also be unset properly.

instrument-cue-name.ly

[image of music]

Instrument names (aligned on axis group spanners) ignore dynamic and pedal line spanners.

instrument-name-dynamic.ly

[image of music]

Instrument names can also be attached to staff groups.

instrument-name-groups.ly

[image of music]

Instrument names are removed when the staves are killed off.

In this example, the second staff (marked by the bar number 2) disappears, as does the instrument name.

instrument-name-hara-kiri.ly

[image of music]

Instrument names are set with Staff.instrument and Staff.instr. You can enter markup texts to create more funky names, including alterations.

instrument-name-markup.ly

[image of music]

Instrument names are also printed on partial starting measures.

instrument-name-partial.ly

[image of music]

Dynamics and Lyrics lines below a PianoStaff do not affect the placement of the instrument name.

instrument-name-pedal-lyrics.ly

[image of music]

InstrumentName is reasonable positioned even for unusual system-start-delimiters.

Below, the instrumentName neither collides with the SystemStartBracket nor moves to far to the left.

instrument-name-system-start-delimiter.ly

[image of music]

Moving the Volta_engraver to the Staff context does not affect InstrumentName alignment.

instrument-name-volta.ly

[image of music]

Instrument names horizontal alignment is tweaked by changing the Staff.InstrumentName.self-alignment-X property. The \layout variables indent and short-indent define the space where the instrument names are aligned before the first and the following systems, respectively.

instrument-name-x-align.ly

[image of music]

Staff margins are also markings attached to bar lines. They should be left of the staff, and be centered vertically with respect to the staff. They may be on normal staves, but also on compound staves, like the PianoStaff.

instrument-name.ly

[image of music]

The switchInstrument music function prints a warning if the given instrument definition does not exist.

instrument-switch-invalid-warning.ly

[image of music]

The switchInstrument music function modifies properties for an in staff instrument switch.

instrument-switch.ly

[image of music]

Engravers which do not exist produce a warning.

invalid-engraver.ly

[image of music]

When \jump is at a line break, the text appears at the end of the line.

jump-break.ly

[image of music]

Where a \jump is not aligned on a measure boundary, the bar line defined by underlyingRepeatBarType appears by default. In this case, “GOTO 10” should have a normal bar line and “GOTO 20” should have a dotted bar line.

jump-unaligned.ly

[image of music]

Grobs attached to system bounds should only keep alive the systems where they are visible. From issue #6519

keep-alive-interfaces-break-invisibility.ly

[image of music]

Each clef has its own accidental placing rules, which can be adjusted using sharp-positions and flat-positions.

key-clefs.ly

[image of music]

Key cancellation signs consists of naturals for pitches that are not in the new key signature. Naturals get a little padding so the stems don’t collide.

key-signature-cancellation.ly

[image of music]

If the clef engraver is removed, the key signature shall use a proper padding > 0 to the start of the staff lines.

key-signature-left-edge.ly

[image of music]

With the padding-pairs property, distances between individual key signature items can be adjusted.

key-signature-padding.ly

[image of music]

When a custom key signature has entries which are limited to a particular octave, such alterations should persist indefinitely or until a new key signature is set.

Here, only the fis’ shows an accidental, since it is outside the octave defined in keyAlterations.

key-signature-scordatura-persist.ly

[image of music]

By setting Staff.keyAlterations directly, key signatures can be set invidually per pitch.

key-signature-scordatura.ly

[image of music]

Key signatures get the required amount of horizontal space.

key-signature-space.ly

[image of music]

Key signatures may appear on key changes, even without a bar line. In the case of a line break, the restoration accidentals are printed at end of a line. If createKeyOnClefChange is set, key signatures are created also on a clef change.

keys.ly

[image of music]

Kievan notation can contain dots, also in ligatures.

kievan-notation-dots.ly

[image of music]

LilyPond typesets Kievan notation.

kievan-notation.ly

[image of music]

When a label straddles at a page break, the chosen page is the second one. This also works when there are several bookparts.

Note: you need to compile this regtest on its own to check it, as the lilypond-book setup does not work for page references.

label-straddling-page-break-bookparts.ly

[image of music]

l.v. ties should not collide with arpeggio indications.

laissez-vibrer-arpeggio.ly

[image of music]

\laissezVibrer ties should also work on individual notes of a chord.

laissez-vibrer-chords.ly

[image of music]

\laissezVibrer ties on beamed notes don’t trigger premature beam slope calculation.

laissez-vibrer-tie-beam.ly

[image of music]

The ’head-direction of a LaissezVibrerTieColumn should be able to be set without causing a segmentation fault.

laissez-vibrer-tie-head-direction.ly

[image of music]

l.v. ties should avoid dots and staff lines, similar to normal ties. They have fixed size. Their formatting can be tuned with tie-configuration.

laissez-vibrer-ties.ly

[image of music]

Scores may be printed in landscape mode.

landscape.ly

[image of music]

Inside of output definitions like \layout or \midi, music is harvested for layout definitions in order to turn them into context modifications.

layout-from.ly

[image of music]

A \layout block inside a \paper block does not error out, and the variables from \paper are accessible in \layout.

layout-in-paper.ly

[image of music]

The ledger-extra grob property increases the number of ledger lines drawn, but they are not drawn on top of staff lines.

ledger-extra.ly

[image of music]

When ledgered notes are very close, for example, in grace notes, they are kept at a minimum distance to prevent the ledgers from disappearing.

ledger-line-minimum.ly

[image of music]

Ledger lines are shortened when they are very close. This ensures that ledger lines stay separate.

ledger-line-shorten.ly

[image of music]

Dynamics and other outside staff objects avoid ledger lines.

ledger-lines-dynamics.ly

[image of music]

In some rare cases like these the extents of two ledger lines at the same vertical position in the same note column do not overlap horizontally, and they should not be merged into a single ledger line. See LSR 505: Displaying complex chords http://lsr.di.unimi.it/LSR/Item?id=505

ledger-lines-non-merging.ly

[image of music]

Ledger lines should appear at every other location for a variety of staves using both line-count and line-positions.

ledger-lines-varying-staves.ly

[image of music]

3 ways to customize ledger line positions.

ledger-positions-customization.ly

[image of music]

Highly tweaked example of lilypond output

les-nereides.ly

[image of music]

Ligature brackets should align to visible or transparent stems only. For stemless notes they should span the whole note width.

ligature-bracket-X-positions.ly

[image of music]

The ligature bracket right-end is not affected by other voices.

ligature-bracket.ly

[image of music]

LilyPond syntax can be used inside scheme to build music expressions, with the #{ ... #} syntax. Scheme forms can be introduced inside these blocks by escaping them with a $, both in a LilyPond context or in a Scheme context.

In this example, the \withpaddingA, \withpaddingB and \withpaddingC music functions set different kinds of padding on the TextScript grob.

lily-in-scheme.ly

[image of music]

Arrows can be applied to text-spanners and line-spanners (such as the Glissando)

line-arrows.ly

[image of music]

Generate valid postscript even if dash-period is small compared to line thickness.

line-dash-small-period.ly

[image of music]

The period of a dashed line is adjusted such that it starts and ends on a full dash.

line-dashed-period.ly

[image of music]

The absence of left or right in the bound-details of a line spanner combined with the presence of non-empty left-broken or right-broken should not cause an error.

line-spanner-bound-details-right-broken-without-right.ly

[image of music]

Setting 'zigzag style for spanners does not cause spacing problems: in this example, the first text markup and zigzag trillspanner have the same outside staff positioning as the second markup and default trillspanner.

line-style-zigzag-spacing.ly

[image of music]

Cover all line styles available.

line-style.ly

[image of music]

Test the different loglevels of lilypond. Run this file with –loglevel=NONE, ERROR, WARN, PROGRESS, DEBUG to see the different loglevels. The errors are commented out. Comment them in to check the output manually.

loglevels.ly

[image of music]

For Voice-derived contexts like CueVoice, the lyrics should still start with the first note.

lyric-combine-derived-voice.ly

[image of music]

If lyrics are assigned to a non-existing voice, a warning should be printed. However, if the lyrics context does not contain any lyrics, then no warning should be printed.

lyric-combine-empty-warning.ly

[image of music]

This tests \lyricsto as the first element of sequential music.

lyric-combine-in-sequential.ly

[image of music]

This tests \lyricsto as an element of simultaneous music.

lyric-combine-in-simultaneous.ly

[image of music]

With the \lyricsto mechanism, individual lyric lines can be associated with one melody line. Each lyric line can be tuned to either follow or ignore melismata.

lyric-combine-new.ly

[image of music]

Lyrics can be aligned to a NullVoice context, which prints no notes, with the usual mechanisms for melismata.

lyric-combine-nullvoice.ly

[image of music]

Polyphonic rhythms and rests do not disturb \lyricsto.

lyric-combine-polyphonic.ly

[image of music]

Lyric repeat counts continue to work when lyrics are applied to music with \lyricsto.

lyric-combine-repeat-count.ly

[image of music]

Switching the melody to a different voice works even if the switch occurs together with context instantiation.

lyric-combine-switch-new-voice.ly

[image of music]

switching voices in the middle of the lyrics is possible using lyricsto.

lyric-combine-switch-voice.ly

[image of music]

A score with lyrics and no music fails gracefully.

lyric-combine-top-level-no-music.ly

[image of music]

Lyrics can be set to a melody automatically. Excess lyrics will be discarded. Lyrics will not be set over rests. You can have melismata either by setting a property melismaBusy, or by setting automaticMelismas (which will set melismas during slurs and ties). If you want a different order than first Music, then Lyrics, you must precook a chord of staves/lyrics and label those. Of course, the lyrics ignore any other rhythms in the piece.

lyric-combine.ly

[image of music]

Lyric extenders run to the end of the line if it continues the next line. Otherwise, it should run to the last note of the melisma.

lyric-extender-broken.ly

[image of music]

A LyricExtender should end at the right place even if there are more notes in the voice than lyrics.

lyric-extender-completion.ly

[image of music]

If includeGraceNotes is enabled, lyric extenders work as expected also for syllables starting under grace notes.

lyric-extender-includegraces.ly

[image of music]

Extender engraver also notices the lack of note heads. Here the extender ends on the 2nd quarter note, despite the grace note without a lyric attached.

lyric-extender-no-heads.ly

[image of music]

If extendersOverRests is set, an extender is not terminated upon encountering a rest.

lyric-extender-rest.ly

[image of music]

Extenders will not protrude into the right margin

lyric-extender-right-margin.ly

[image of music]

A LyricExtender may span several notes. A LyricExtender does not extend past a rest, or past the next lyric syllable.

lyric-extender.ly

[image of music]

Hyphens are printed at the beginning of the line only when they go past the first note, or when property after-line-breaking is #t.

lyric-hyphen-break.ly

[image of music]

No hyphen should be printed under a grace note at the start of a line if the grace’s main note starts a new syllable.

lyric-hyphen-grace.ly

[image of music]

The minimum distance between lyrics is determined by the minimum-distance of LyricHyphen and LyricSpace.

The ideal length of a hyphen is determined by its length property, but it may be shortened down to minimum-length in tight situations. If in this it still does not fit, the hyphen will be omitted.

Like all overrides within \lyricsto and \addlyrics, the effect of a setting is delayed is one syllable.

lyric-hyphen-retain.ly

[image of music]

A lyric hyphen or vowel transition may occur anywhere in a sequence of skips. It spans the entire sequence.

lyric-hyphen-skip.ly

[image of music]

Using the whiteout-color property it is possible to adjust the whiteout of lyric hyphens.

lyric-hyphen-whiteout-color.ly

[image of music]

In lyrics, hyphens may be used.

lyric-hyphen.ly

[image of music]

If ignoreMelismata is set, lyrics should remain center-aligned.

lyric-ignore-melisma-alignment.ly

[image of music]

lyricMelismaAlignment sets the default alignment for melismata. It works with both automatic and manual melismata.

lyric-melisma-alignment.ly

[image of music]

Melismata may be entered manually by substituting _ for lyrics on notes that are part of the melisma.

lyric-melisma-manual.ly

[image of music]

A syllable aligned with a melisma delimited with \melisma and \melismaEnd should be left-aligned.

lyric-melisma-melisma.ly

[image of music]

When lyrics are not associated with specific voices, the lyric placement should follow lyric rhythms. In particular, the second syllable here should not be attached to the first note of the first staff.

lyric-no-association-rhythm.ly

[image of music]

Lyrics should still slide under TimeSignature when an OctaveEight is present.

lyric-octave-eight.ly

[image of music]

Normally, the lyric is centered on the note head. However, on melismata, the text is left aligned on the left-side of the note head.

lyric-phrasing.ly

[image of music]

No lyric repeat count appears at the end of a volta alternative.

lyric-repeat-count-alternatives.ly

[image of music]

At a line break, a lyric repeat count is visible at the end of the line.

lyric-repeat-count-break.ly

[image of music]

This shows the default format of LyricRepeatCount and that it can be overridden.

lyric-repeat-count-format.ly

[image of music]

A lyric repeat count is placed at the end of a repeated section even when that occurs during a rest. In this test, an arrow marks the expected position of the repeat count.

lyric-repeat-count-rest.ly

[image of music]

This tests the appearance of repeats for modern transcriptions of Gregorian chant. The repeat count appears in the lyric line under the finalis sign (double line) that ends the repeated section, even if the repeat count is 1. The count is an italicized lowercase roman number followed by a period. A final “i” is replaced by “j”.

lyric-repeat-count.ly

[image of music]

Tildes in lyric syllables are converted to tie symbols.

lyric-tie.ly

[image of music]

The \tweak function can be used in Lyrics.

lyric-tweak.ly

[image of music]

Lyrics can be structured using repeats with alternative endings. This case has a repeat that ends at the end of the score.

lyric-volta-alternative-end.ly

[image of music]

Lyrics can be structured using repeats with alternative endings. This case has a repeat that ends before the end of the score. The volta bracket ends before the rest.

lyric-volta-alternative.ly

[image of music]

Lyrics can be structured using repeats and \fine. In the folded output, Fine should appear at the end of the first measure.

lyric-volta-fine.ly

[image of music]

Lyrics are ignored for aftergrace notes.

lyrics-after-grace.ly

[image of music]

Lyrics aligned above a context should stay close to that context when stretching. The Bass I lyric line stays with the Bass staff.

lyrics-aligned-above-stay-close-to-staff.ly

[image of music]

Adding a Bar_engraver to the Lyrics context makes sure that lyrics do not collide with bar lines.

lyrics-bar.ly

[image of music]

Setting includeGraceNotes enables lyrics syllables to be assigned to grace notes.

lyrics-includegraces.ly

[image of music]

Lyric syllables of widely varying length do not disproportionately affect bar lengths. In this example both scores should fit on one line. The first score’s system should not exceed line-width. The bars in the second score’s system should be of roughly equal length.

lyrics-long-syllables.ly

[image of music]

Melismata are triggered by manual beams. Notes in a melisma take their natural spacing over a long syllable.

lyrics-melisma-beam.ly

[image of music]

Lyric syllables without note attachment are aligned correctly even if the paper column is very wide.

lyrics-no-notes.ly

[image of music]

Long lyrics should be allowed to pass under the bar line.

lyrics-pass-under-bar.ly

[image of music]

Empty measures and extraordinary bar-line thickness do not confuse SpanBarStub. These lyrics should remain clear of the span bars.

lyrics-spanbar.ly

[image of music]

Lyrics are not lowered despite the presence of a clef transposition (8 below the clef).

lyrics-tenor-clef.ly

[image of music]

Dot size and beamlet length should be scaled along with notation size when using the \magnifyMusic command.

magnifyMusic-dots-beamlets.ly

[image of music]

Laissez vibrer ties should be scaled along with notation size when using the \magnifyMusic command. They can get thicker than the default, but not thinner.

magnifyMusic-laissez-vibrer-ties.ly

[image of music]

Phrasing slurs should be scaled along with notation size when using the \magnifyMusic command. They can get thicker than the default, but not thinner.

magnifyMusic-phrasing-slurs.ly

[image of music]

Repeat ties should be scaled along with notation size when using the \magnifyMusic command. They can get thicker than the default, but not thinner.

magnifyMusic-repeat-ties.ly

[image of music]

Slurs should be scaled along with notation size when using the \magnifyMusic command. They can get thicker than the default, but not thinner.

magnifyMusic-slurs.ly

[image of music]

Stem length/thickness, beam spacing/thickness, and horizontal spacing should be scaled along with notation size when using the \magnifyMusic command. Stems can get thicker than the default, but not thinner.

magnifyMusic-stem-beam-spacing.ly

[image of music]

Tablature half-note double-stems should be scaled along with notation size when using the \magnifyMusic command.

magnifyMusic-tablature-double-stems.ly

[image of music]

All text-interface grobs should have baseline-skip and word-space values scaled along with notation size when using the \magnifyMusic command.

magnifyMusic-text-interface.ly

[image of music]

Ties should be scaled along with notation size when using the \magnifyMusic command. They can get thicker than the default, but not thinner.

magnifyMusic-ties.ly

[image of music]

Bar line thickness and spacing should be scaled along with notation size when using the \magnifyStaff command.

magnifyStaff-bar-lines.ly

[image of music]

Dot size and beamlet length should be scaled along with notation size when using the \magnifyStaff command.

magnifyStaff-dots-beamlets.ly

[image of music]

\magnifyStaff also works for Dynamics contexts. This test should print a huge forte dynamic.

magnifyStaff-dynamics.ly

[image of music]

In a piece with a single, magnified staff, the presence of a bar number does not affect spacing from the left edge. The clefs in the two systems should appear the same distance from the left edge.

magnifyStaff-left-edge-bar-number.ly

[image of music]

In a piece with a single, magnified staff, the presence of a rehearsal mark does not affect spacing from the left edge. The clefs in the two systems should appear the same distance from the left edge.

magnifyStaff-left-edge-rehearsal-mark.ly

[image of music]

space-alist values should be scaled along with notation size when using the \magnifyStaff command.

magnifyStaff-space-alist.ly

[image of music]

Staff line thickness should be scaled along with staff size when using the \magnifyStaff command. Staff lines can get thicker than the default, but not thinner.

magnifyStaff-staff-line-thickness.ly

[image of music]

Tablature half-note double-stems should be scaled along with notation size when using the \magnifyStaff command.

magnifyStaff-tablature-double-stems.ly

[image of music]

All text-interface grobs that are within the Staff context should have baseline-skip and word-space values scaled along with notation size when using the \magnifyStaff command.

magnifyStaff-text-interface.ly

[image of music]

Alternative notation systems using accidentals different from the Western ones set them systematically, for standalone markups and all grobs that print accidentals.

This include file provides a function to draw many accidental in different contexts. It is used by various tests.

makam-accidental-glyphs.ly

[image of music]

make-relative has to copy its argument expressions in case the generated music expression is getting copied and modified.

The code here defines a \reltranspose function working inside of \relative and uses it. Both staves should appear identical.

make-relative-copies.ly

[image of music]

make-relative can make relativization on music function calls behave as one would expect from looking at the function’s arguments rather than at the actually resulting expressions. This regtest defines an example function \withOctave which works equally well inside and outside of \relative.

make-relative-music.ly

[image of music]

make-relative is a Scheme utility macro mainly useful for creating music functions accepting pitches as arguments. Its purpose is to make music functions taking pitch arguments for producing complex music fragments integrate nicely within a \relative section. This regtest typesets a short music fragment twice, once without using \relative, once using it. The fragment should appear identical in both cases.

make-relative.ly

[image of music]

When the break-align-symbols property is given as a list, the alignment depends on which symbols are visible.

mark-align-priority.ly

[image of music]

Marks still align correctly if Mark_engraver is moved to Staff context.

mark-align-staff-context.ly

[image of music]

Text_mark_engraver may be moved to staff-group contexts. Five marks should appear in black above the second staff from the top. The same marks should appear in red above the third staff from the top.

mark-align-staff-group-context.ly

[image of music]

\markLengthOn also works nicely regardless of direction.

mark-length-direction.ly

[image of music]

LilyPond issues warnings when \mark markup conflicts with certain other simultaneous marks, and engraves only the first.

Marks 1! to 3! should appear alone. Marks 4! to 8! should appear with various performance marks.

mark-tracking-conflict-ad-hoc-mark.ly

[image of music]

LilyPond issues warnings when \codaMark \default conflicts with certain other simultaneous marks, and engraves only the first.

Coda marks 1 to 3 should appear with various rehearsal marks. Coda marks 4 to 6, 8, and 9 should appear alone.

mark-tracking-conflict-default-coda-mark.ly

[image of music]

LilyPond issues warnings when \mark \default conflicts with certain other simultaneous marks, and engraves only the first.

Rehearsal marks 1, 2, and 4 should appear alone. Rehearsal marks 5 to 9 should appear with various performance marks.

mark-tracking-conflict-default-rehearsal-mark.ly

[image of music]

LilyPond issues warnings when \segnoMark \default conflicts with certain other simultaneous marks, and engraves only the first.

Segno marks 1 to 3 should appear with various rehearsal marks. Segno mark 4 and then 9 to 12 should appear alone.

mark-tracking-conflict-default-segno-mark.ly

[image of music]

LilyPond issues warnings when \sectionLabel conflicts with certain other simultaneous marks, and engraves only the first.

Section labels 1! to 3! should appear with various rehearsal marks. Section labels 4! to 8! should appear alone.

mark-tracking-conflict-section-label.ly

[image of music]

LilyPond issues warnings when \codaMark n conflicts with certain other simultaneous marks, and engraves only the first.

Coda marks 1 to 3 should appear with various rehearsal marks. Coda marks 4 to 8 should appear alone.

mark-tracking-conflict-specific-coda-mark.ly

[image of music]

LilyPond issues warnings when \mark n conflicts with certain other simultaneous marks, and engraves only the first.

Rehearsal marks 1 to  3 should appear alone. Rehearsal marks 4 to 9 should appear with various performance marks.

mark-tracking-conflict-specific-rehearsal-mark.ly

[image of music]

LilyPond issues warnings when \segnoMark n conflicts with certain other simultaneous marks, and engraves only the first.

Segno marks 1 to 3 should appear with various rehearsal marks. Segno marks 4 to 8 should appear alone.

mark-tracking-conflict-specific-segno-mark.ly

[image of music]

Mark_tracking_translators operate independently in independent contexts. The upper staff has marks 1, 2, and 3. The lower staff has marks 2, 3, and 1 at the same points.

mark-tracking-context.ly

[image of music]

The Mark_tracking_translator manages one rehearsal-mark sequence for (potentially) many Mark_engravers. The expected marks on both staves are these: 1, 2, 9, 10, 12, 13, 20, 21.

mark-tracking-sequence.ly

[image of music]

Accidentals can be printed with the \accidental markup command (and derived commands). In text the \text-accidental markup command (and its children) yields proper aligning. Both markup commands are protected against overrides of font-name

markup-accidentals.ly

[image of music]

The markup command \align-on-other accepts both numbers and ##f as position arguments; the latter indicates that the object’s reference point should be used for alignment.

markup-align-on-other.ly

[image of music]

The feta font has arrow heads

markup-arrows.ly

[image of music]

The explicit directional embedding codes, U+202A and U+202B, are supported in single-line markup strings. The embeddings must be terminated with the pop directional formatting character, U+202C.

markup-bidi-explicit-embedding.ly

[image of music]

The explicit directional override codes, U+202D and U+202E, are supported in single-line markup strings. The overrides must be terminated with the pop directional formatting character, U+202C.

markup-bidi-explicit-overrides.ly

[image of music]

The implicit directional marks, U+200E and U+200F, are supported in single-line markup strings.

markup-bidi-implicit-marks.ly

[image of music]

A single Pango string is processed according to the Unicode Bidirectional Algorithm. The strong Hebrew characters in this example are set right-to-left, and the Latin numerals, space character, and punctuation are set according to the rules of the algorithm.

markup-bidi-pango.ly

[image of music]

If \left-brace or \right-brace cannot find a match for the given point size, it should default gracefully to either brace0 or brace575 and display a warning.

markup-brace-warning.ly

[image of music]

The markup command \left-brace selects a fetaBraces glyph based on point size, using a binary search. \right-brace is simply a \left-brace rotated 180 degrees.

markup-braces.ly

[image of music]

Text markup using center-column shall still reserve space for its whole width and not overwrite the previous stencil.

markup-center-align-nocollision.ly

[image of music]

Fixed horizontal alignment of columns of text can be set using \left-column, \center-column and \right-column.

markup-column-align.ly

[image of music]

test various markup commands.

markup-commands.ly

[image of music]

The \compound-meter markup command can produce various kinds of numeric time signature.

markup-compound-meter.ly

[image of music]

Test markup commands used for conditional constructs. See also markup-conditionals-single-page.ly.

markup-conditionals-several-pages.ly

[image of music]

Test markup commands used for conditional constructs. See also markup-conditionals-several-pages.ly.

markup-conditionals-single-page.ly

[image of music]

Cyclic markup definitions should cause a warning, but not crash LilyPond with an endless loop

markup-cyclic-reference.ly

[image of music]

When a markup command takes a music argument, it sets the default duration for the following music, whereas a duration argument does not.

markup-default-duration.ly

[image of music]

Markups have a maximum depth to prevent non-termination.

markup-depth-non-terminating.ly

[image of music]

Diacritic marks are rendered and positioned correctly. The diacritic on line 1 looks like a lower-underline and is centered beneath the main character. The diacritic on line 2 is positioned to the left of the main character, with a tiny space of separation. The diacritic on line 3 is positioned directly above the main character, either centered or shifted slightly to the left.

markup-diacritic-marks.ly

[image of music]

The epsfile markup command reads an EPS file

markup-eps.ly

[image of music]

The eyeglasses markup function prints out eyeglasses.

markup-eyeglasses.ly

[image of music]

Fingerings and bass figures in markup are scaled with the font size.

markup-finger-figuredbass-fontsize.ly

[image of music]

The markup command \first-visible uses the first argument that produces a non-empty stencil and ignores the rest.

The expected markup on this score is "Lame Songs for Testing" followed by a "C" time signature symbol.

markup-first-visible.ly

[image of music]

Text is framed properly with \box, \circle, \oval and \ellipse

markup-frame-text.ly

[image of music]

Text markup using \hspace with positive and negative arguments.

markup-hspace.ly

[image of music]

The file extension of a file passed to \markup \image can be uppercased.

markup-image-file-extension-uppercase.ly

[image of music]

The \image markup command supports PNG and EPS images. The background-color property can be set, defaulting to a white background.

markup-image.ly

[image of music]

A warning is emitted when a markup command does not return a stencil as it should.

markup-invalid-stencil.ly

[image of music]

The markup-commands \draw-dashed-line, \draw-dotted-line and \draw-squiggle-line should print the same visual length as \draw-line. Also testing possible overrides for \draw-squiggle-line

markup-line-styles.ly

[image of music]

The thickness setting between markup lines and other lines is consistent.

markup-line-thickness.ly

[image of music]

Text that can spread over pages is entered with the \markuplist command. It can be assigned to a variable and inserted at top-level with or without preceding it by \markuplist.

markup-lines-identifier.ly

[image of music]

Text that can spread over pages is entered with the \markuplist command. Widowed and orphaned lines are avoided at the begininng and end of a \markuplist containing more than one line.

markup-lines.ly

[image of music]

This concatenates the same markup list several times.

markup-list-append.ly

[image of music]

\markupMap can be used for applying a markup function to music properties throughout a music expressions, like the text of all contained lyric events.

markup-map.ly

[image of music]

Markup commands can take music arguments, enclosed in braces. A bare pitch or duration is accepted.

markup-music-argument.ly

[image of music]

Reset fontname for musicglyph. For unknown glyphs, we print a warning.

markup-music-glyph.ly

[image of music]

A dotted whole note displayed via the \note command must separate the note head and the dot. The dot avoids the upflag.

markup-note-dot.ly

[image of music]

In the \note markup command, the position of dots may be changed.

markup-note-dots-direction.ly

[image of music]

The 'style property from grobs such as TimeSignature and TextSpanner does not affect the default note head style for \note and \note-by-number.

markup-note-grob-style.ly

[image of music]

The note-by-number markup-command is robust with all kinds of size changings. For every Stem the vertical length and thickness prints reasonable.

markup-note-sizes.ly

[image of music]

\note-by-number and \note support all note head styles and all flag styles (default, straight, flat, mensural).

markup-note-styles.ly

[image of music]

The note markup function may be used to make metronome markings. It works for a variety of flag, dot and duration settings.

markup-note.ly

[image of music]

Partial markups acts as a chain of markup commands where everything but some arguments of the final markup command has already been supplied.

markup-partial.ly

[image of music]

The \path markup command supports the filled property to toggle its fill.

markup-path-fill.ly

[image of music]

The \path markup command supports the line-cap-style property with values of butt, round, and square.

markup-path-linecap.ly

[image of music]

The \path markup command supports the line-join-style property with values of bevel, round, and miter.

markup-path-linejoin.ly

[image of music]

The \path markup command allows the user to draw arbitrary paths using a simple syntax. The two paths below should be identical.

markup-path.ly

[image of music]

A markup command can take a pitch argument and receive it between braces.

markup-pitch-argument.ly

[image of music]

The markup function \rest supports all rest styles.

markup-rest-styles.ly

[image of music]

The rest markup function works for a variety of style, dot and duration settings. Printing symbols for MultiMeasureRest is supported.

markup-rest.ly

[image of music]

The output of \markup \rhythm scales with font size automatically.

markup-rhythm-font-size.ly

[image of music]

\markup \rhythm is not affected by switching off ragged-right globally.

markup-rhythm-ragged.ly

[image of music]

Settings can be applied to \markup \rhythm, either using music commands in the music argument, or using a \layout block.

markup-rhythm-tweaking.ly

[image of music]

\markup \rhythm draws a standalone rhythmic pattern. All beaming is explicit.

markup-rhythm.ly

[image of music]

There is a Scheme macro markup to produce markup texts using a similar syntax as \markup.

markup-scheme.ly

[image of music]

\markup \score displays all systems. Spacing between systems is set using baseline-skip.

markup-score-multi-system.ly

[image of music]

Use \score block as markup command.

markup-score.ly

[image of music]

A list of special character ASCII aliases can be easily included. This works for markups and lyrics.

markup-special-characters.ly

[image of music]

It works to splice an empty list inside markup.

markup-splice-empty-list.ly

[image of music]

Markup scripts may be stacked.

markup-stack.ly

[image of music]

The markup list command \string-lines splits a given string at line break characters and drops surrounding whitespace from the resulting strings. Other splitting points may be achieved by overriding the split-char property.

markup-string-lines.ly

[image of music]

Demo of markup texts, using LilyPond syntax.

markup-syntax.ly

[image of music]

Triangles should scale appropriately with font size.

markup-triangle-scaling.ly

[image of music]

Users may define non-standard markup commands using the define-markup-command scheme macro.

markup-user.ly

[image of music]

\verbatim-file works on Unicode data. It decodes the file as UTF-8.

markup-verbatim-file-utf8.ly

[image of music]

The markup commands \with-true-dimension and \with-true-dimensions give a markup the extents given by the stencil’s outline.

markup-with-true-dimensions.ly

[image of music]

The markup commands \wordwrap and \justify produce simple paragraph text.

markup-word-wrap.ly

[image of music]

Measure counters follow alternative numbering when active. This also works with compressed multi-measure rests.

measure-counter-alternative-numbering.ly

[image of music]

Measures split across line breaks may be numbered in a measure count. Each segment receives a number. The first number has its ordinary appearance, but numbers after the break are enclosed in parentheses.

measure-counter-broken.ly

[image of music]

When a measure counter extends over a compressed multi-measure rest, it displays the full measure range. By default, the two measure numbers in the range are dash-separated; this is configurable.

measure-counter-compressed-mmrest.ly

[image of music]

\startMeasureCount and \stopMeasureCount coming in the same time step in this order do not cause a warning.

measure-counter-event-order.ly

[image of music]

Measure counts are not confused by grace notes.

measure-counter-grace.ly

[image of music]

The spacing-pair property may be used to adjust the horizontal positioning of MeasureCounter objects relative to prefatory material. In the following example, the count should be aligned with the full-measure rests.

measure-counter-spacing-pair.ly

[image of music]

The staff-padding property may be used to adjust the distance of MeasureCounter objects from the staff. The following example uses staff-padding to align the count vertically.

measure-counter-staff-padding.ly

[image of music]

Measures can be numbered sequentially by enclosing them with \startMeasureCount and \stopMeasureCount.

measure-counter.ly

[image of music]

The Measure_grouping_engraver also starts triangles and brackets at moments where no new note or rest starts.

measure-grouping-all-moments.ly

[image of music]

The Measure_grouping_engraver adds triangles and brackets above beats when the beats of a time signature are grouped.

measure-grouping.ly

[image of music]

The ends of measure spanners may be aligned in various ways.

measure-spanner-spacing-pair.ly

[image of music]

Measure spanners can span single and multiple measures. They may be texted or untexted and hold markups.

measure-spanner.ly

[image of music]

Mensural ligatures show different shapes, depending on the rhythmical pattern and direction of the melody line.

mensural-ligatures.ly

[image of music]

LilyPond supports mensural music (including Kievan square notation) by providing special contexts.

This test shows basic note values but no ligatures.

mensural.ly

[image of music]

Test for merging rest numbers using the Merge_mmrest_numbers_engraver. The upper staff is the new default with the engraver enabled while the second one is the old default resulting in collisions. The final staff demonstrates the additional use of Merge_rests_engraver.

merge-mmrest-numbers-engraver.ly

[image of music]

Test for merging rests in different voices.

merge-rests-engraver.ly

[image of music]

Test for vertical positions of merged rests in magnified staves.

merge-rests-magnify-staff.ly

[image of music]

A MetronomeMark, RehearsalMark and BarNumber should not effect the starting point of spanners.

metronome-mark-broken-bound.ly

[image of music]

metronomeMarkFormatter supports all note head styles and flags styles. Setting font-name for MetronomeMark does not disturb the glyphs for note-head and flag.

metronome-mark-formatter.ly

[image of music]

Metronome marks aligned on notes do not interfere with the positioning of loose columns in other staves. Here the loose column supporting the clef is correctly placed immediately before the second note in the lower staff.

metronome-mark-loose-column.ly

[image of music]

Metronome marks respect symbol order in break-align-symbols.

In this example, the default is changed to '(time-signature key-signature): since key-signature is second in the list, the mark should only be aligned with the key signature if there is no time signature present, as in the second measure.

metronome-marking-align-order.ly

[image of music]

\tempo marks are aligned with the time signature or the position of the first note.

By overriding break-align-symbols the default alignment can be changed. If no symbol in break-align-symbols is present, the property non-break-align-symbols determines the alignment. If the alignment object is a multi-measure rest, the tempo mark is aligned with the preceding bar line.

metronome-marking-break-align.ly

[image of music]

Non-integer metronome rates are rounded for printing. The counts should be 0, 50, 0-50, and 75-100.

metronome-marking-fractional.ly

[image of music]

Metronome marks are placed correctly if Metronome_mark_engraver is moved to StaffGroup context. Metronome marks should appear above the middle staff (the upper staff of the group) only.

metronome-marking-staff-group-context.ly

[image of music]

Here \tempo directives are printed as metronome markings.

The marking is left aligned with the time signature, if there is one.

metronome-marking.ly

[image of music]

A metronome marking can be added to a multimeasure rest whose engraver was moved to the Staff, without segfaulting.

metronome-multimeasure-rest-no-segfault.ly

[image of music]

Using an empty text in the metronome marks, one can generate parenthesized tempo marks.

metronome-parenthesized.ly

[image of music]

Tempo ranges are supported. By default, numbers are printed with an en-dash character, separated by thin-spaces.

metronome-range.ly

[image of music]

The tempo command supports text markup and/or ‘duration=count’. Using Score.tempoHideNote, one can hide the ‘duration=count’ in the tempo mark.

metronome-text.ly

[image of music]

If after-writing is set in the \midi block, it is called after every MIDI file that is written. The visual and MIDI output are not important in this test.

midi-after-writing.ly

[image of music]

Midi can create drums.

midi-drums.ly

[image of music]

Midi also handles crescendo and decrescendo, either starting and ending from specified or unspecified sound level.

midi-dynamics.ly

[image of music]

Grace notes shorten previous notes only if they’d overlap them. The A should be a full quarter note, but the C should be shortened to 1/4 - 9/40 * 1/8 = 71/320 (rounded down to 340/384 in MIDI).

midi-grace-after-rest.ly

[image of music]

Tied notes sound as one note in MIDI. Grace notes following a tied note shorten the resulting single note in MIDI.

midi-grace-after-tie.ly

[image of music]

Grace notes don’t intrroduce syncing problems: the last note off will appear at tick 768 (2 * 384).

midi-grace.ly

[image of music]

MIDI key signatures are output, using an approximate key signature if MIDI format cannot represent the true key signature

midi-key-signature.ly

[image of music]

Lyrics in MIDI are aligned to ties and beams: this examples causes no bar checks in MIDI.

midi-lyric-barcheck.ly

[image of music]

Microtonal shifts should be corrected before the start of the next (possibly grace) note.

midi-microtone-off.ly

[image of music]

The pitch wheel is used for microtones.

midi-microtone.ly

[image of music]

A MIDI note-off event precedes a simultaneous note-on event for the same pitch in the same MIDI channel, so that all notes are heard. Run timidity -idvvv file.midi |grep Midi to see midi events.

midi-notes.ly

[image of music]

MIDI and partial measures work together.

midi-partial.ly

[image of music]

Pedals. Run timidity -idvvv file.midi |grep Midi to see midi events.

midi-pedal.ly

[image of music]

Converting LilyPond input to MIDI and then again back with midi2ly.py is a reversible procedure in some simple cases, which mean that the original .ly -file and the one converted back from the generated .midi -file do not differ. Here are produced some scales.

midi-scales.ly

[image of music]

should deliver f’ in MIDI

midi-transposition.ly

[image of music]

Midi2ly tuplet test.

  python scripts/midi2ly.py --duration-quant=32 \
      --allow-tuplet=4*2/3 \
      --allow-tuplet=8*2/3 \
      --allow-tuplet=4*3/5 \
      --allow-tuplet=8*3/5 \
      tu.midi 

midi-tuplets.ly

[image of music]

In overlapping unisons, within a single MIDI channel, either the first note is truncated, or the notes are merged if midiMergeUnisons is #t. Run timidity -idvvv file.midi |grep Midi to see midi events.

midi-unisons.ly

[image of music]

The full orchestra plays a note, where groups stop one after another. Use this to tune equalizer settings.

midi-volume-equaliser.ly

[image of music]

The property minimum-length-after-break can be used to stretch broken spanners starting after a line break. The following example shows usage for a variety of spanners.

minimum-length-after-break.ly

[image of music]

The following shows the interaction between the properties minimum-length and minimum-length-after-break. When minimum-length is used alone, both segments of the tie are affected. The properties minimum-length-after-break only affects the sibling starting a line. Both properties may be used together to create independent changes of both siblings. This example shows that both properties have an identical effect on the sibling after the break.

minimum-length-broken-ties.ly

[image of music]

Long spanners at the end of the lines stretch measures correctly.

minimum-length-end-line.ly

[image of music]

If Score.skipBars is set, the signs for four, two, and one measure rest are combined to produce the graphical representation of rests for up to 10 bars. The number of bars will be written above the sign.

mm-rests2.ly

[image of music]

\modalTranspose, \retrograde, \inversion and \modalInversion work for an octatonic motif.

modal-transforms.ly

[image of music]

The sans serif style tab clef is automatically adjusted to different string spacings.

modern-tab-clef-scaled.ly

[image of music]

Sans serif style tab clefs are supported by \clef moderntab. This alternative clef supports four- to seven-stringed instruments and is scaled automatically.

modern-tab-clef.ly

[image of music]

Whole notes in a monochord must be properly offset so that the heads just touch each other. On the other hand, a stem should touch both notes.

monochords.ly

[image of music]

The source is a rather tightly set Peters in Edition is a heavy font. The Peters edition (4622c) was ‘herausgegeben’ by Paul Losse, whose name also appears on a 1956 edition of some other music. Strictly speaking, his edititorial enhancements will not be in the PD - but I am assuming there are no notable ones in this small piece.

The original compresses the entire music onto a single page, in 4 systems. Lily does so too if you tune down spacing-increment, but chooses line breaks differently.

Further manual tweaks: the slur in measure 12 has been flattened manually. The beam in measure 3, left-hand, technically is wrong, but has been added following the original. The crescendo in measure 4 has been lowered

morgenlied.ly

[image of music]

This is the Mozart 3 for horn. It’s from an Edition Breitkopf EB 2563, edited by Henri Kling. Henri Kling (1842-1918) was a horn virtuoso that taught in Geneva.

mozart-hrn-3.ly

[image of music]

The multimeasure rest is centered exactly between bar lines.

multi-measure-rest-center.ly

[image of music]

The existence of a text mark does not affect the placement of a multimeasure rest.

multi-measure-rest-center2.ly

[image of music]

A multi-measure rest implicitly creates a bottom context. The expected output is a repeated section with one whole-measure rest in the body and one whole-measure rest in one alternative.

multi-measure-rest-create-context.ly

[image of music]

Multi-measure rests are centered also in the case of grace notes.

multi-measure-rest-grace.ly

[image of music]

There are both long and short instrument names. Engraving instrument names should not be confused by the multimeasure rests.

multi-measure-rest-instr-name.ly

[image of music]

Though the default spacing for multi-measure rests is affected by prefatory matter in other staves, centering can be restored by overriding spacing-pair.

multi-measure-rest-multi-staff-center.ly

[image of music]

Multi measure rests don’t segfault when there is no staff symbol.

multi-measure-rest-no-staff.ly

[image of music]

Setting restNumberThreshold affects only future multi measure rests. Unsetting it works without crashes.

The rests should be numbered 2, (none), 1, 2, 1, (none), and 2.

multi-measure-rest-number-threshold.ly

[image of music]

A multi measure rest reminder is a reminder printed at the top of the page, to remember how many measures you were counting.

This is a demo of user-defined engravers, and defining grobs using ly:make-grob-properties.

multi-measure-rest-reminder.ly

[image of music]

By setting texts starting with a multi-measure rest, an extra spacing column is created. This should not cause problems.

multi-measure-rest-spacing.ly

[image of music]

Multi measure rest staff position can be overridden to 0.

multi-measure-rest-staff-position.ly

[image of music]

Only whole, breve, longa and maxima rests are used by default for multi-measure rests.

multi-measure-rest-standard.ly

[image of music]

Scripts and texts may be added to the multi-measure rests. This test covers such rests under various spanners. This used to crash (issue #6085).

multi-measure-rest-text-spanned.ly

[image of music]

Scripts and texts may be added to the multi-measure rests.

By setting the appropriate spacing-procedure, we can make measures stretch to accommodate wide texts.

multi-measure-rest-text.ly

[image of music]

Multi-measure rests standard values can be tweaked.

multi-measure-rest-tweaks.ly

[image of music]

Multi-measure rests do not collide with bar lines and clefs. They are not expanded when you set Score.skipBars. Although the multi-measure-rest is a Spanner, minimum distances are set to stop it colliding with bar lines.

Rests over measures lasting longer than 2 wholes use breve rests. When more than 10 measures (tunable through expand-limit) are used then a different symbol is used.

multi-measure-rest.ly

[image of music]

Multiple overrides to the default time signature settings can be added. In this example, notes should be beamed as indicated by the markups.

multiple-time-sig-settings.ly

[image of music]

Music functions can be called directly from Scheme.

music-function-direct-call.ly

[image of music]

the endSpanners music function inserts end span events at the end of a note.

music-function-end-spanners.ly

[image of music]

For defining a music function, one can supply one or several music function calls chained together, cutting the last call short using \etc. The remaining arguments are supplied when calling the music function defined in this manner.

music-function-incomplete.ly

[image of music]

Music functions may be attached to notes; in this case they must be introduced by a direction indicator. If a non-neutral direction is given (i.e. anything else than a dash), then the ’direction property of the resulting object is set accordingly.

music-function-post-event.ly

[image of music]

Music functions accept strings as markup arguments when using the type predicate markup?

music-function-string-markup.ly

[image of music]

Music functions are generic music transformation functions, which can be used to extend music syntax seamlessly. Here we define and use a \myBar function which works like \bar.

music-function.ly

[image of music]

music-map also recurses into articulations.

music-map-articulations.ly

[image of music]

With music-map, you can apply functions operating on a single piece of music to an entire music expression. In this example, the function notes-to-skip changes a note to a skip. When applied to an entire music expression in the 1st measure, the scripts and dynamics are left over. These are put onto the 2nd measure.

music-map.ly

[image of music]

Nested fill-lines should work properly. In this example, both occurrences of FOO should be centered.

nested-fill-lines.ly

[image of music]

addlyrics do not need braces around their arguments, in particular if the arguments are variables.

newaddlyrics-music-identifiers.ly

[image of music]

newlyrics, multiple stanzas, multiple lyric voices.

newaddlyrics.ly

[image of music]

no-header.ly

[image of music]

LilyPond does not render zero-duration scores. This test should produce neither MIDI nor visual output.

no-music.ly

[image of music]

The printing of the staff lines may be suppressed by removing the corresponding engraver.

no-staff.ly

[image of music]

Bar lines are positioned correctly when using custom staves which are not centered around position 0.

non-centered-bar-lines.ly

[image of music]

By default, text is set with empty horizontal dimensions. The property extra-spacing-width in TextScript is used to control the horizontal size of text.

non-empty-text.ly

[image of music]

Whether simultaneous notes are identified as vertically colliding or not depends on the value of the note-collision-threshold property of the Stem grob (for notes in the same voice) and the NoteCollision grob (for notes in different voices).

note-collision-threshold.ly

[image of music]

Notes can be set in the Aiken (Christian Harmony) style.

note-head-aiken.ly

[image of music]

Note heads are placed on the correct side of the stem; this placement changed is not changed by magic values of layout-set-staff-size. (Fix of issue 5303.)

note-head-chord-layout-set-staff-size.ly

[image of music]

Note heads are flipped on the stem to prevent collisions. It also works for whole heads that have invisible stems.

note-head-chord.ly

[image of music]

Notes can be set in the Funk (Harmonia Sacra) style.

note-head-funk.ly

[image of music]

Dots on harmonic note heads can be shown by setting the property harmonicDots.

note-head-harmonic-dotted.ly

[image of music]

A harmonic note head must be centered if the base note is a whole note.

note-head-harmonic-whole.ly

[image of music]

The handling of stems for harmonic notes must be completely identical to normal note heads.

Harmonic heads do not get dots. If harmonicAccidentals is unset, they also don’t get accidentals.

note-head-harmonic.ly

[image of music]

Notes can be set in the Sacred Harp style.

note-head-sacred-harp.ly

[image of music]

Shape notes can be set to work properly in minor keys.

note-head-shape-minor.ly

[image of music]

With shapeNoteStyles, the style of the note head is adjusted according to the step of the scale, as measured relative to the tonic property.

note-head-solfa.ly

[image of music]

Notes can be set in the Southern Harmony style.

note-head-southern-harmony.ly

[image of music]

Note head shapes may be set from several choices. The stem endings should be adjusted according to the note head. If you want different note head styles on one stem, you must create a special context.

Harmonic notes have a different shape and different dimensions.

note-head-style.ly

[image of music]

Notes can be set in the Walker (Christian Harmony) style.

note-head-walker.ly

[image of music]

Note head lines (e.g. glissando) run between centers of the note heads.

note-line.ly

[image of music]

Note names may be printed in various languages, with or without accidentals and octave marks.

note-name-context-custom.ly

[image of music]

NoteNames context should be close to the related notes, and should not collide with the tempo markings.

note-names-context.ly

[image of music]

NoteNames and ChordNames contexts have (limited) support for makam notation. The alteration glyphs displayed in these two contexts should be the same as the ones on the staff.

note-names-makam.ly

[image of music]

Various languages are supported for note names input. Selecting another language within a music expression is possible, and doesn’t break point-and-click abilities.

note-names.ly

[image of music]

Noteheads do not extend above the upper staff line.

notehead-height.ly

[image of music]

NullVoice’ responds to \change Staff as a ‘Voice’ would. In consequence, in the first shown system it keeps a single treble-clef staff alive. In the second system, it is in a single bass-clef staff.

nullvoice-change.ly

[image of music]

A NullVoice context handles slurs without errors.

nullvoice-slur.ly

[image of music]

The number of stafflines of a staff can be set. Ledger lines both on note heads and rests, as well as bar lines, are adjusted accordingly.

number-staff-lines.ly

[image of music]

The \offset command may be used to displace various properties from the default settings contained in grob descriptions. Settings which may be offset are limited to those of type number, number-pair, or number-pair-list. Most of the following examples begin with the grob in its default appearance. The command is demonstrated as a tweak and as an override.

offsets.ly

[image of music]

heavily mutilated Edition Peters Morgenlied by Schubert

one-line-auto-height-breaking.ly

[image of music]

heavily mutilated Edition Peters Morgenlied by Schubert

one-line-breaking.ly

[image of music]

heavily mutilated Edition Peters Morgenlied by Schubert

one-page-breaking.ly

[image of music]

OneStaff contexts can be used for letting several contexts use the same vertical position. This example shows chords being placed in a staff and immediately following it.

one-staff.ly

[image of music]

The optimal page breaker will make trade-offs between horizontal and vertical stretching so that the overall spacing will be more acceptable. The page-spacing-weight parameter controls the relative importance of vertical/horizontal spacing. Because ragged-last-bottom is on, there is no penalty for odd vertical spacing on the final page. As a result, only the first page should be horizontally stretched.

optimal-page-breaking-hstretch.ly

[image of music]

Test functionality of the -danti-alias-factor command-line option. Affects PNG output only.

option-anti-alias-factor.ly

[image of music]

Test functionality of the -dpng-width and -dpng-height command-line options. Affects PNG output only.

option-png-width-height.ly

[image of music]

Test backup of predicate-based optional music function arguments.

Unit expressions like 3\cm can’t be parsed as optional arguments in one go since they would require lookahead after 3. The predicate is checked after 3, and if it is suitable, Lilypond commits to parsing as a unit number, and checks the result again. For the predicate integer? and 3\cm, you would actually get a syntax error (since the combination is no longer an integer) rather than Lilypond trying to see 3\cm as two separate arguments.

optional-args-backup.ly

[image of music]

Test predicate-based optional music function argument skipping.

optional-args-predicate.ly

[image of music]

Test optional music function arguments. The output is nonsensical, but if you wrack your brain, you’ll figure it out. Remember that optional arguments are matched left to right, and after the first non-match, the rest is skipped.

optional-args.ly

[image of music]

At line breaks, ottava brackets have no vertical line and their horizontal line does not stick out. The dashed line runs until the end of the line (regardless of prefatory matter).

ottava-broken.ly

[image of music]

Consecutive ottavas with the same label are not incorrectly merged.

ottava-consecutive.ly

[image of music]

Both edge heights of an ottava bracket can be specified.

ottava-edge.ly

[image of music]

User tweaks to OttavaBracket.direction are honored in all cases.

In this test, marcato marks show the expected placement.

ottava-explicit-direction.ly

[image of music]

The text property of an OttavaBracket grob may be overridden.

ottava-explicit-text.ly

[image of music]

Ottava brackets can be made to apply to a single voice by moving the Ottava_spanner_engraver to Voice context.

ottava-per-voice.ly

[image of music]

Ottava brackets are supported, through the use of the music function \ottava.

The spanner should go below a staff for 8va bassa, and the ottavation markup can be tuned with Staff.ottavation.

ottava.ly

[image of music]

LilyPond should warn about missing ottavation markups only if there is a list of ottavation markups defined. This is not the case for MIDI performers, so do not output a warning.

ottavation-markups-midi.ly

[image of music]

Ottavation markups can be changed by the user. LilyPond warns about missing markups (in this example for +3 and -3 octaves).

ottavation-markups.ly

[image of music]

Shows the output-attributes property of a grob being set. This should have no effect in the Postscript backend. In the SVG backend these settings should produce this group tag: <g id="123" class="foo" data-whatever="bar"> … </g>

output-attributes.ly

[image of music]

The outside-staff-placement-directive adjusts the order in which objects are placed outside the staff.

outside-staff-placement-directive.ly

[image of music]

A sublist of grob property lists may be overridden within a callback. This test uses a custom stencil callback which changes the Y coordinate of the right bound of the glissando spanner.

override-nest-scheme.ly

[image of music]

Sublist of grob property lists may be also tuned. In the next example, the beamed-lengths property of the Stem grob is tweaked.

override-nest.ly

[image of music]

Page breaks work when they are placed at the end of a score, or between scores.

page-break-between-scores.ly

[image of music]

Page breaking and page turning commands (\pageBreak, \noPageBreak, etc), can be used at top level.

page-break-turn-toplevel.ly

[image of music]

Page breaks are allowed by default at the end of the score, but the user can override them. There should be one line on the first page and two (colliding) lines on the second page.

page-breaking-end-of-score.ly

[image of music]

The page breaking algorithm can handle clefs combined with lyrics. That is, the Y-extent approximations are a little more accurate than just using bounding boxes. In particular, everything should fit on one page here.

page-breaking-good-estimation.ly

[image of music]

The height of marks is taken into account during page breaking.

page-breaking-marks.ly

[image of music]

Padding between markups is honored by the page breaker. This should take up two pages.

page-breaking-markup-padding.ly

[image of music]

Padding between a markup and a system is honored by the page breaker. This should take up two pages.

page-breaking-markup-padding2.ly

[image of music]

Padding between a score and a markup is honored by the page breaker. This should take up two pages.

page-breaking-markup-padding3.ly

[image of music]

The max-systems-per-page variable prevents more than a given number of systems from being on a page. Titles are not counted as systems. \noPageBreak can override max-systems-per-page in unusual situations.

page-breaking-max-systems-per-page.ly

[image of music]

minimum-distance is correctly accounted for in page breaking.

page-breaking-min-distance.ly

[image of music]

minimum-distance within a system is correctly accounted for in page breaking.

page-breaking-min-distance2.ly

[image of music]

minimum-distance within a system is correctly accounted for in page breaking.

page-breaking-min-distance3.ly

[image of music]

The min-systems-per-page variable forces each page to have a minimum number of systems. Titles do not count as systems here.

page-breaking-min-systems-per-page1.ly

[image of music]

The min-systems-per-page variable takes precedence over the desire not to overfill a page. In this case, systems will overlap because they are forced to be on the page.

page-breaking-min-systems-per-page2.ly

[image of music]

The height-estimation routine takes into account the fact that the TextScript needs to be moved up to avoid the note. This should be spaced on two pages.

page-breaking-outside-staff-estimation.ly

[image of music]

The height-estimation routine doesn’t get confused by multiple outside-staff grobs in the same measure.

page-breaking-outside-staff-estimation2.ly

[image of music]

A warning is emitted when page-count is negative or zero.

page-breaking-page-count-positive.ly

[image of music]

The number of pages in a score can be forced by setting page-count in the (book-level) paper block.

page-breaking-page-count1.ly

[image of music]

The number of pages in a score can be forced by setting page-count in the (book-level) paper block. If there are too few systems for the number of pages, we append blank pages.

page-breaking-page-count2.ly

[image of music]

The number of pages in a score can be forced by setting page-count in the (book-level) paper block. Even if there are too many systems for that number of pages, we will squeeze them in.

page-breaking-page-count3.ly

[image of music]

system-count and \pageBreak are compatible.

page-breaking-system-count-forced-break.ly

[image of music]

The systems-per-page variable forces a certain number of systems per page. Titles are not counted as systems.

page-breaking-systems-per-page.ly

[image of music]

Stress optimal page breaking. This should look nice and even on 4 a6 pages.

page-breaks.ly

[image of music]

Page-headers and -footers. All headers and footers should be printed on their specified page.

page-headers-and-footers.ly

[image of music]

Page labels on loose columns are not ignored: this includes both mid-line unbreakable columns which only contain labels and columns with empty bar lines (and no other break-aligned grobs).

page-label-loose-column.ly

[image of music]

Page labels may be placed inside music or at top-level, and referred to in markups. Labels created with \tocItem (and thus bearing an internally-generated unique identifying symbol) remain referrable by their user-specified name.

page-label.ly

[image of music]

By setting extra-offset within the line-break-system-details of NonMusicalPaperColumn, systems may be moved in relation either to their default position on the printable area of the page or the absolute position specified by X-offset or Y-offset within line-break-system-details.

page-layout-extra-offset.ly

[image of music]

By setting Y-offset and X-offset for the line-break-system-details of NonMusicalPaperColumn, systems may be placed absolutely on the printable area of the page.

page-layout-manual-position.ly

[image of music]

This shows how different settings on \paper modify the general page layout. Basically \paper will set the values for the whole paper while \layout for each \score block.

This file is best viewed outside the collated files document.

page-layout.ly

[image of music]

Links to labels should not break if the label doesn’t exist.

page-links-nolabel.ly

[image of music]

Links to labels and explicit page number (PDF backend only).

page-links.ly

[image of music]

Minimal page breaker: special case when the last system is moved to an other page when there is not enough space because of the tagline.

page-minimal-page-breaking-last-page.ly

[image of music]

The minimal page breaker stacks as many lines on pages, only accounting for manual page break commands.

page-minimal-page-breaking.ly

[image of music]

Test the different options for page number formatting.

page-number-type.ly

[image of music]

Layouts that overflow a page will be compressed in order to fit on the page, even if it causes collisions. In this example, the tagline should not collide with the bottom staff.

page-overflow-compression.ly

[image of music]

alignment-distances applies to the toplevel VerticalAlignment but not to BassFigureAlignment. The 4 in the bass figure line should be directly below the 6.

page-spacing-bass-figures.ly

[image of music]

The spring at the bottom of a page is fairly flexible (much more so than the one at the top), so it does not drag the staff to the bottom of the page. However, it is sufficiently stiff to cause stretching.

page-spacing-bottom-spring.ly

[image of music]

Dynamic centering still works with alignment-distances.

page-spacing-dynamics.ly

[image of music]

Adjacent lines of markup are placed as closely together as possible.

page-spacing-markups.ly

[image of music]

Having markup after a non-staff line doesn’t confuse the page layout engine.

page-spacing-nonstaff-lines-and-markup.ly

[image of music]

The vertical spacing engine is not confused by a non-staff line below a system followed by a loose line above the next system. Systems are spaced far enough that loose lines are not interleaved, even if gaps would allow interleaving.

page-spacing-nonstaff-lines-between-systems.ly

[image of music]

Non-staff lines between two systems don’t confuse the layout engine. In particular, they don’t interfere with system-system-spacing, which controls the flexible spacing between the two closest staves of consecutive systems.

page-spacing-nonstaff-lines-between.ly

[image of music]

A non-staff line (such as Lyrics) at the bottom of a system gets spaced appropriately.

page-spacing-nonstaff-lines-bottom.ly

[image of music]

Padding from the header and footer is measured to the first non-staff line, whether or not it is spaceable.

page-spacing-nonstaff-lines-header-padding.ly

[image of music]

Spacing rules between Staves coexist with rules affecting non-staff lines. Here, the padding separating items on different staves is larger than the padding for associated lyrics.

page-spacing-nonstaff-lines-independent.ly

[image of music]

Relative indentation between systems is taken into account in allowing space for loose lines between systems.

page-spacing-nonstaff-lines-skylines.ly

[image of music]

A non-staff line (such as Lyrics) at the top of a system is spaced appropriately.

page-spacing-nonstaff-lines-top.ly

[image of music]

Non-staff lines (such as Lyrics) can specify their padding or minimum-distance to the staff for which they don’t have affinity.

page-spacing-nonstaff-lines-unrelated.ly

[image of music]

The space taken up by rehearsal marks is correctly accounted for, even though they live in the Score context.

page-spacing-rehearsal-mark.ly

[image of music]

StaffGrouper interacts correctly with \RemoveEmptyStaves. In both systems, there should be a large space between the staff groups.

page-spacing-staff-group-hara-kiri.ly

[image of music]

StaffGroups can be nested, in which case the inner StaffGroup wins.

page-spacing-staff-group-nested.ly

[image of music]

By default, the staves within a StaffGroup are spaced more closely than staves not in a StaffGroup.

page-spacing-staff-group.ly

[image of music]

The stretchability property affects the amount that staves will move under extreme stretching, but it does not affect the default distance between staves.

page-spacing-stretchability.ly

[image of music]

Page breaking doesn’t crash when the line-breaking is invalid.

page-spacing-system-count-overfull.ly

[image of music]

Page layout and stretching work with system-count enabled.

page-spacing-system-count.ly

[image of music]

Both the page breaking and the page layout take account of the heights of the header and footer.

page-spacing-tall-headfoot.ly

[image of music]

top-markup-spacing controls the spacing from the top of the printable area (i.e. the bottom of the top margin) to a title or markup, when it is the first item on a page.

page-spacing-top-markup-spacing.ly

[image of music]

top-system-spacing controls the spacing to the first non-title staff on every page.

page-spacing-top-system-spacing.ly

[image of music]

By setting page-top-space, the Y position of the first system can be forced to be uniform.

page-top-space.ly

[image of music]

By default, we start with page 1, which is on the right hand side of a double page. In this example, auto-first-page-number is set to ##t and the music won’t fit on a single page, so we should automatically set the first page number to 2 in order to avoid a bad page turn.

page-turn-page-breaking-auto-first-page.ly

[image of music]

By default, we start with page 1, which is on the right hand side of a double page. In this example, auto-first-page-number is set to ##t. Although the first measure could go on a page by itself, this would require stretching the first page badly, so we should automatically set the first page number to 2 in order to avoid a bad page turn.

page-turn-page-breaking-auto-first-page2.ly

[image of music]

If there are no good places to have a page turn, the optimal-breaker will just have to recover gracefully. This should appear on 3 pages.

page-turn-page-breaking-badturns.ly

[image of music]

Allowing the first command column to be breakable caused a crash in Page_turn_page_breaking.

page-turn-page-breaking-first-column.ly

[image of music]

The page-turn engraver will not count potential page turns if they occur in the middle of a repeat unless there is a long gap at the beginning or at the end of the repeat.

page-turn-page-breaking-repeats.ly

[image of music]

Page_turn_engraver places a page turn after a rest unless there is a ’special’ bar line within the rest, in which case it places the turn at the special bar line. In this case, the engraver operates in Score context.

page-turn-page-breaking-score.ly

[image of music]

Page_turn_engraver places a page turn after a rest unless there is a ’special’ bar line within the rest, in which case it places the turn at the special bar line. In this case, the engraver operates in Voice context.

page-turn-page-breaking-voice.ly

[image of music]

Page_turn_engraver places a page turn after a rest unless there is a ’special’ bar line within the rest, in which case it places the turn at the special bar line. In this case, the engraver operates in Staff context.

page-turn-page-breaking.ly

[image of music]

it is allowed to start a score with a page break

page-turn-start-with-page-break.ly

[image of music]

The palm mute technique for stringed instruments is supported by triangle-shaped note heads.

palm-mute.ly

[image of music]

Objects like articulations, lyrics, dynamics, etc., are aligned correctly even when they aren’t attached directly to notes.

An object’s parent may be a PaperColumn (instead of a more usual NoteHead); this can happen, for example, when a DynamicText grob is attached to a spacer rest, or when a Lyrics context doesn’t have the associatedVoice property set. In that case, LilyPond should find note heads belonging to this PaperColumn and align the object on these note heads. If there are no note heads in the PaperColumn, the object are aligned using a placeholder extent to ensure consistent spacing between objects attached to PaperColumns and NoteHeads grobs.

Note that the placeholder extent is not used if there are any note heads in the respective PaperColumn grob, even if they have empty stencils.

In the test cases below the PaperColumn grob location has been marked with a blue line.

paper-column-grob-alignment.ly

[image of music]

Default values for margins, indents, and offsets are accessible in paper-defaults-init.ly and apply to the default paper size returned by (ly:get-option ’paper-size). For other paper sizes, they are scaled linearly.

paper-default-margins-a6.ly

[image of music]

Default values for margins, indents, and offsets are accessible in paper-defaults-init.ly and apply to the default paper size returned by (ly:get-option ’paper-size). For other paper sizes, they are scaled linearly.

paper-default-margins-def.ly

[image of music]

Margin values must fit the line-width, that means: paper-width = line-width + left-margin + right-margin. In case they do not, default margins are set and a warning is printed.

paper-margins-consistency.ly

[image of music]

Here only left-margin is given, right-margin will remain default.

paper-margins-left-margin.ly

[image of music]

If only line-width is given, systems are horizontally centered.

paper-margins-line-width.ly

[image of music]

All checks can be avoided by setting check-consistency to ##f in \paper.

paper-margins-no-checks.ly

[image of music]

Normally, margin settings must not cause systems to run off the page.

paper-margins-overrun.ly

[image of music]

Here only right-margin is given, left-margin will remain default.

paper-margins-right-margin.ly

[image of music]

Paper margin settings do not have to be complete. Missing values are added automatically. If no paper settings are specified, default values are used.

paper-margins.ly

[image of music]

Nested properties can be set in the paper block.

paper-nested-override.ly

[image of music]

Setting individual nested paper properties does not remove existing settings or break spacing annotation.

paper-nested-override2.ly

[image of music]

Setting a custom default paper size.

paper-size-custom-default.ly

[image of music]

Setting a custom paper size (landscape).

paper-size-custom-landscape.ly

[image of music]

Setting a custom paper size.

paper-size-custom.ly

[image of music]

In two-sided mode, a binding offset can be specified, which is added to the inner margin automatically.

paper-twosided-bcorr.ly

[image of music]

Two-sided mode allows you to use different margins for odd and even pages.

paper-twosided.ly

[image of music]

\parallelMusic does not complain about incomplete bars at its end.

parallelmusic-partial.ly

[image of music]

When parent-alignment-X property is unset, the value of self-alignment-X will be used as the factor for parent alignment. This happens e.g. for LyricTexts.

parent-alignment-synchronized-with-self-alignment.ly

[image of music]

Parenthesizing breakable items such as breathing signs also work at line ends.

parenthesize-breakable.ly

[image of music]

When \parenthesize applies to a chord, the parentheses enclose all notes in the chord. In tablature one needs to enter \parenthesize NoteColumn

parenthesize-chords.ly

[image of music]

Parentheses are correctly placed when placed on a note head that is on the right of its stem and has an accidental.

parenthesize-horizontal-placement.ly

[image of music]

Parentheses only cause minimum distances to be set. They should not cause more space to be allowed for a note when they do not cause a collision with the previous or the following note.

parenthesize-horizontal-spacing-cosy.ly

[image of music]

Space is reserved so that parentheses do not cause collisions between columns.

parenthesize-horizontal-spacing-tight.ly

[image of music]

\laissezVibrer can be parenthesized without programming errors.

parenthesize-laissezvibrer.ly

[image of music]

The parenthesize markup will place parentheses around any stencil.

The angularity of the parentheses can be adjusted.

parenthesize-markup.ly

[image of music]

Parentheses around notes also include accidentals and dots; they are centered on the vertical center of the combined enclosed items.

parenthesize-notes-accidentals.ly

[image of music]

The \parenthesize function should also work on single notes (not inside chords), rests, and on whole chords. Also, parenthesizing articulations, dynamics and text markup is possible. On all other music expressions, \parenthesize does not have an effect.

Measure 1: Three parenthesized notes (staccato not parenthesized), one note with staccato in parentheses; Measure 2: Chord and two rests in parentheses (accent and markup not); Measure 3: note (no parentheses) with \p in parentheses, with text in parentheses, and note in parentheses with \p not in parentheses, rest (no parentheses); Measure 4: shows that \parenthesize does not apply to other expressions like SequentialMusic.

parenthesize-singlenotes-chords-rests.ly

[image of music]

Parenthesizing spanners is supported.

parenthesize-spanners.ly

[image of music]

\parenthesize can take the name of the grob to be parenthesized. It then acts like a \once \override.

parenthesize-time-based.ly

[image of music]

The parenthesize function is a special tweak that encloses objects in parentheses. The associated grob is Score.Parentheses.

parenthesize.ly

[image of music]

It is possible to use the part combiner for three voices with \partCombineUp and \partCombineDown.

part-combine-3voices.ly

[image of music]

The a2 string is printed only on notes (i.e. not on rests), and only after chords, solo or polyphony.

part-combine-a2.ly

[image of music]

The part combiner has an option to set the range of differences in steps between parts that may be combined into chords.

part-combine-chord-range.ly

[image of music]

The part combiner stays apart for crossing voices.

part-combine-cross.ly

[image of music]

If the part-combiner shows two separate voices, multi-measure rests are supposed to use the same settings as \voiceOnce and \voiceTwo.

part-combine-force-mmrest-position.ly

[image of music]

Overrides for the part-combiner, affecting only one moment. The partCombine...Once override applies only to one moment, after which the old override – if any – is in effect again.

part-combine-force-once.ly

[image of music]

Overrides for the part-combiner. All functions like \partCombineApart and \once \partCombineApart are internally implemented using a dedicated partCombineForced context property.

part-combine-force.ly

[image of music]

The analysis of the part combiner is non-local: in the following example, the decision for using separate voices in the 1st measure is made on the 2nd note, but influences the 1st note.

In the 2nd measure, the pattern without the tie, leads to combined voices.

part-combine-global.ly

[image of music]

The notes of the first chord share a stem but the notes of the second chord do not.

part-combine-inside-grace.ly

[image of music]

Music functions that scale durations also scale \partCombine decisions.

part-combine-inside-scale-durations.ly

[image of music]

\keepWithTag works with \partCombine.

part-combine-keep-with-tag.ly

[image of music]

Part combine texts accept markup.

part-combine-markup.ly

[image of music]

Normal rests are preferred over multi-measure rests. A multi-measure rest beginning in one part in the middle of a multi-measure rest in the other part appears as expected.

part-combine-mmrest-after-apart-silence.ly

[image of music]

Multimeasure rests are printed after solos, both for solo1 and for solo2.

part-combine-mmrest-after-solo.ly

[image of music]

The positioning of multimeasure rests in \partCombineApart passages corresponds with \voiceOne and \voiceTwo even when using non-standard staves.

part-combine-mmrest-apart.ly

[image of music]

Multi-measure rests do not have to begin and end simultaneously to be combined.

part-combine-mmrest-shared.ly

[image of music]

\partCombine needs to be given pitches in their final octaves, so if \relative is used it must be applied inside \partCombine. The pitches in \partCombine are unaffected by an outer \relative, so that the printed output shows the pitches that \partCombine used.

The expected output of this test is three identical measures.

part-combine-relative.ly

[image of music]

Different kinds of silence are not merged into the shared voice even if they begin and end simultaneously; however, when rests and skips are present in the same part, the skips are ignored.

part-combine-silence-mixed.ly

[image of music]

Rests must begin and end simultaneously to be merged into the shared voice.

part-combine-silence.ly

[image of music]

\partCombine handles slurs without errors.

part-combine-slur.ly

[image of music]

SOLO is printed even if the solo voice ends before the other one. Unfortunately, the multi-rest of the 1st voice (which is 2 bars longer than the 2nd voice) does not get printed.

part-combine-solo-end.ly

[image of music]

In this example, solo1 should not be printed over the 1st note, because of the slur which is present from the one-voice to the two-voice situation.

part-combine-solo-global.ly

[image of music]

A solo string can only be printed when a note starts. Hence, in this example, there is no Solo-2 although the 2nd voice has a dotted quarter, while the first voice has a rest.

A Solo indication is only printed once; (shared) rests do not require reprinting a solo indication.

Solo 1/2 can not be used when a spanner is active, so there is no solo over any of the tied notes.

part-combine-solo.ly

[image of music]

Test some transitions that might be found in string parts produced with \partCombine.

part-combine-strings.ly

[image of music]

Wait for the next real note for part-combine texts (i.e. don’t print part-combine texts on rests). This is needed because the part-combiner needs an override if one voice has a full-bar rest while the other has some rests and then a solo.

part-combine-text-wait.ly

[image of music]

The part combiner detects a2, solo1 and solo2, and prints texts accordingly.

part-combine-text.ly

[image of music]

End tuplets events are sent to the starting context, so even after a switch, a tuplet ends correctly.

part-combine-tuplet-end.ly

[image of music]

Tuplets in combined parts only print one bracket.

part-combine-tuplet-single.ly

[image of music]

The part combiner can combine parts of unequal lengths.

part-combine-unequal-lengths.ly

[image of music]

Grace notes in parts are combined.

part-combine-with-grace.ly

[image of music]

The new part combiner stays apart from:

  • different durations,
  • different articulations (taking into account only slur/beam/tie), and
  • wide pitch ranges.

part-combine.ly

[image of music]

In the unexpected case that \partial specifies a duration shorter than the following note, a bar line still appears after the specified duration.

The score in common time should have four bar lines. The score in 3/4 time should have six bar lines.

partial-add-moment.ly

[image of music]

\partial can be can be called in mid piece in multiple contexts. Measure 2 should contain two beamed eighth notes.

partial-in-mid-piece.ly

[image of music]

\partial produces a warning when used at the start of the piece when Timing.measureLength is infinite. In this test, a time signature remains in effect though the measure length is changed. This test should run with expected warnings only.

partial-infinite-measure-length-at-start.ly

[image of music]

\partial produces a warning when used in mid piece when Timing.measureLength is infinite. In this test, a time signature remains in effect though the measure length is changed. This test should run with expected warnings only.

partial-infinite-measure-length-in-mid-piece.ly

[image of music]

\partial can create measures longer than the length dictated by the time signature.

partial-long.ly

[image of music]

\partial works with polymetric staves.

partial-polymetric.ly

[image of music]

Ensure that certain paths are drawn correctly and do not cause division by zero.

path-edge-case.ly

[image of music]

Exercise various situations in path stencils.

path-exercise.ly

[image of music]

The extents of a path stencil are correctly computed when it contains consecutive moveto commands.

path-extents-consecutive-movetos.ly

[image of music]

Curve path stencils have correct extents.

path-extents-curve.ly

[image of music]

\pattern and \fill-with-pattern markup commands should interpret their arguments only once. This test calls them with a markup command that counts how often it is evaluated. The first line is supposed to show just ‘1’ multiple times, the second line uses numbers ‘2’ to ‘4’.

pattern-markup-evaluation.ly

[image of music]

In some fonts, the same glyph is used to render differing code points. In this file, the Japanese font uses the same glyph for representing U+898B and U+2F92. However, when running the output of this file through pdftotext, the original codepoints are returned.

pdf-copy-paste.ly

[image of music]

Header fields can contain \fromproperty #'header:xxx markups. They are correctly converted to strings in PDF metadata.

Warning: the current regression testing infrastructure will not notice if this test breaks.

pdf-metadata-fromproperty.ly

[image of music]

PDF metadata need either Latin1 encoding (not UTF8) or full UTF-16BE with BOM. The title field uses full UTF-16 (russian characters, euro, etc), while the composer uses normal european diacrits (which need to be encoded as Latin1, not as UTF8). Closing parenthesis need to be escaped by a backslash AFTER encoding!

pdfmark-metadata-unicode.ly

[image of music]

The PDF backend uses several header fields to store metadata in the resulting PDF file. Header fields with the prefix pdf override those without the prefix for PDF creation (not for visual display on the page).

pdfmark-metadata.ly

[image of music]

The brackets of a piano pedal should start and end at the left side of the main note-column. If a note is shared between two brackets, these ends are flared.

At a line-break, there are no vertical endings. Pedal changes can be placed at spacer rests.

pedal-bracket.ly

[image of music]

Unterminated piano pedal brackets run to the end of the piece.

pedal-end.ly

[image of music]

The standard piano pedals style comes with Ped symbols. The pedal string can be also tuned, for example, to a shorter tilde/P variant at the end of the melody.

pedal-ped.ly

[image of music]

One notation style for Persian music uses the sori and koron accidental glyphs.

persian-accidental-glyphs.ly

[image of music]

Test Persian key signatures.

persian-key-signatures.ly

[image of music]

The appearance of phrasing slurs may be changed from solid to dotted or dashed.

phrasing-slur-dash.ly

[image of music]

LilyPond does not support multiple concurrent phrasing slurs with the parentheses syntax. In this case, warnings will be given and the nested slur will not be generated. However, one can can create a second slur with a different spanner-id.

phrasing-slur-multiple.ly

[image of music]

PhrasingSlurs go over normal slurs.

phrasing-slur-slur-avoid.ly

[image of music]

Phrasing slurs do not collide with tuplet numbers.

phrasing-slur-tuplet.ly

[image of music]

Point-and-click information can be generated only for certain event types.

point-and-click-types.ly

[image of music]

The \polygon markup command draws polygons according to the properties filled, thickness and extroversion.

polygon.ly

[image of music]

This tests polymetric staves beginning at different times, with upbeats specified with \partial. One staff in 4/4 time and another in 3/4 time should end simultaneously. A third staff in 2/4 time should begin simultaneously with the staff in 3/4 time (apart from its grace note) and end after 2 full measures in 3/4 time. The ossia staves should have bar 1 after the upbeat, as usual.

polymeter-ossia-partial.ly

[image of music]

This tests polymetric staves beginning at different times. One staff in 4/4 time and another in 3/4 time should end simultaneously. A third staff in 2/4 time should begin simultaneously with the staff in 3/4 time (apart from its grace note) and end after 2 measures in 3/4 time.

polymeter-ossia.ly

[image of music]

The \enablePolymeter command turns on polymetric notation, making time signatures independent between staves.

polymeter.ly

[image of music]

Multiple post events can be attached from Scheme expressions.

post-events-from-scheme.ly

[image of music]

Multiple post events can be grouped into a single post-event-like expression that dissolves into its constituents as soon as it becomes attached to a music expression. When property modifiers (such as tweaks or direction) or other are applied to those, they are transfered to the contained elements rather than being ignored.

post-events-wrapper-direction.ly

[image of music]

When multiple post events are wrapped, they are ordered the same as if they had not been wrapped. Tweaks applied to the wrapper are applied to every element.

post-events-wrapper-ordering.ly

[image of music]

Transposition by less than one octave up or down should not affect predefined fretboards.

predefined-fretboards-transpose.ly

[image of music]

Predefined fretboards and chord shapes can be added.

predefined-fretboards.ly

[image of music]

Prefatory items maintain sufficient separation from musical notation for readability, even in tight spacing. The notes should remain generally on the correct side of the time signature, key signature and bar lines. A key change to G major should be legible.

prefatory-separation.ly

[image of music]

Distances between prefatory items (e.g. clef, bar, etc.) are determined by engraving standards. These distances depend on which items are combined. Mid-line, the order for clefs and bar lines is different from the start of line.

prefatory-spacing-matter.ly

[image of music]

Using the printInitialRepeatBar property, repeat bar lines can be printed automatically at the start of the piece.

print-initial-repeat-bar.ly

[image of music]

heavily mutilated Edition Peters Morgenlied by Schubert

profile-property-access.ly

[image of music]

Property overrides and reverts from \grace do not interfere with the overrides and reverts from polyphony.

property-grace-polyphony.ly

[image of music]

Nested properties may be overridden using Scheme list syntax. This test performs two property overrides: the first measure uses standard \override syntax; the second uses a list.

property-nested-override.ly

[image of music]

nested properties may also be reverted. This uses Scheme list syntax.

property-nested-revert.ly

[image of music]

Once properties take effect during a single time step only.

property-once.ly

[image of music]

\unset should be able to unset the ‘DrumStaff’-specific ‘clefGlyph’ equally well as layout instruction, in a context definition, or as context modification. All systems here should revert to the ‘Score’-level violin clef.

property-unset.ly

[image of music]

Adding material to a tag in sequential and simultaneous expressions using \pushToTag and \appendToTag. One should get the equivalent of

{ c' e' g' <<c' e' g' c''>> <<c'' g' e' c'>> g' e' c' }

push-to-tag.ly

[image of music]

QR codes can be created with all four possible error correction levels.

qr-code-error-correction-level.ly

[image of music]

Test QR codes with different versions (i.e., matrix sizes).

qr-code-version.ly

[image of music]

The \qr-code markup command inserts a QR code, which can be printed at an arbitrary size. The padding around it scales with the size.

qr-code.ly

[image of music]

The cueDuring form of quotation will set stem directions on both quoted and main voice, and deliver the quoted voice in the cue Voice. The music function \killCues can remove all cue notes.

Spanners run to the end of a cue section, and are not started on the last note.

quote-cue-during.ly

[image of music]

The cueDuring and quoteDuring forms of quotation use the variables quotedCueEventTypes and quotedEventTypes to determine which events are quoted. This allows different events to be quoted for cue notes in comparison to normal quotes.

quotedEventTypes is also the fallback for cue notes if quotedCueEventTypes is not set.

quote-cue-event-types.ly

[image of music]

Two quoted voices may refer to each other. In this example, there are notes with each full-bar rest.

quote-cyclic.ly

[image of music]

\quoteDuring and \cueDuring shall properly quote voices that create a sub-voice. The sub-voice will not be quoted, though. Exceptions are sections of parallel music << {...} \ {...} >>, which will be quoted.

quote-during-subvoice.ly

[image of music]

With \cueDuring and \quoteDuring, fragments of previously entered music may be quoted. quotedEventTypes will determines what things are quoted. In this example, a 16th rest is not quoted, since rest-event is not in quotedEventTypes.

quote-during.ly

[image of music]

A warning should be produced for empty quoted music.

quote-empty.ly

[image of music]

Quotes may contain grace notes. The grace note leading up to an unquoted note is not quoted.

quote-grace.ly

[image of music]

\killCues shall only remove real cue notes generated by \cueDuring, but not other music quoted using \quoteDuring.

quote-kill-cues.ly

[image of music]

The \quoteDuring command shall also quote correctly all \override, \once \override, \revert, \set, \unset and \tweak events. The first line contains the original music, the second line quotes the whole music and should look identical.

By default, not all events are quoted. By setting the quoted event types to '(StreamEvent), everything should be quoted.

quote-overrides.ly

[image of music]

Voices from different cues must not be tied together. In this example, the first note has a tie. This note should not be tied to the second visible note (following the rest). Note that this behavior will not hold for cues in direct succession, since only one CueVoice context is created (with context-id ‘cue’).

quote-tie.ly

[image of music]

Quotations take into account the transposition of both source and target. In this example, all instruments play sounding central C, the target is a instrument in F. The target part may be \transposed. The quoted pitches will stay unchanged.

quote-transposition.ly

[image of music]

Tuplet bracket ends properly when quoting.

quote-tuplet-end.ly

[image of music]

In cue notes, Tuplet stops are handled before new tuplets start.

quote-tuplet.ly

[image of music]

With \quote, fragments of previously entered music may be quoted. quotedEventTypes will determines what things are quoted. In this example, a 16th rest is not quoted, since rest-event is not in quotedEventTypes.

quote.ly

[image of music]

For a one-page score, ragged-bottom should have the same effect as ragged-last-bottom.

ragged-bottom-one-page.ly

[image of music]

When a score takes up only a single line and it is compressed, it is not printed as ragged.

ragged-right-compressed.ly

[image of music]

When ragged-right is specifically disabled, a score with only one line will not be printed as ragged.

ragged-right-disabled.ly

[image of music]

When a score takes up only a single line and it is stretched, it is printed as ragged by default.

ragged-right-one-line.ly

[image of music]

Parts of a string that are the result of an automatic replacement are not processed themselves for replacements.

recursive-text-replacement.ly

[image of music]

Marks are put on top a breakable symbol, according to the value of break-align-symbols grob property. The same holds for BarNumber grobs.

rehearsal-mark-align.ly

[image of music]

Rehearsal marks with direction DOWN get placed at the bottom of the score.

rehearsal-mark-direction.ly

[image of music]

A rehearsal mark at the end of the score does not cause programming errors or strange output.

rehearsal-mark-end-of-score.ly

[image of music]

Rehearsal marks at the end of the last measure of a score are automatically made visible.

rehearsal-mark-final-score.ly

[image of music]

Comparison of rehearsalMarkFormatter functions.

The marks should read H, K, I, K, 93, XCVI, XCVJ, 8, AB, CC, Dd, xcvi, xcvj, iij., boxed A, circled B, ovalled C, medium font D.

rehearsal-mark-formatters.ly

[image of music]

Rehearsal marks in letter style: the I is skipped, and after Z, double letters are used. The mark may be set with \mark NUMBER, or with Score.rehearsalMark.

rehearsal-mark-letter.ly

[image of music]

Marks can be printed as numbers. By setting rehearsalMarkFormatter we may choose a different style of mark printing. Also, marks can be specified manually, with a markup argument.

rehearsal-mark-number.ly

[image of music]

Using repeat unfold within a relative block gives a different result from writing the notes out in full. The first system has all the notes within the stave. In the second, the notes get progressively higher.

relative-repeat.ly

[image of music]

Notes are entered using absolute octaves, octaves relative to the previous note, or relative to a fixed octave.

relative.ly

[image of music]

\RemoveEmptyStaves is defined separately from context definitions so it can be used outside of \layout blocks.

remove-empty-context-mod.ly

[image of music]

RemoveEmptyStaves should keep the pre-existing value of auto-knee-gap. In this case, the cross-staff beam should be between the two staves.

remove-empty-staves-auto-knee.ly

[image of music]

remove-empty-staves-dynamics.ly

[image of music]

Rests should not keep staves alive when \RemoveEmptyStaves is active. The following example should have only one staff.

remove-empty-staves-with-rests.ly

[image of music]

The VerticalAxisGroup.remove-layer property can be used to keep staves alive with reference to other staves in the Keep_alive_together_engraver group.

remove-layer-symbol.ly

[image of music]

Bar numbers on repeat bar lines do not depend on the order in which Bar_number_engraver and Repeat_acknowledge_engraver run. The two systems in this test should be identical.

repeat-bar-number-engraver-order.ly

[image of music]

This tests D.C. al Coda form and how it unfolds.

repeat-dc-al-coda.ly

[image of music]

This tests D.C. al Fine form and how it unfolds.

repeat-dc-al-fine.ly

[image of music]

This tests D.C. al Coda form, but with a segno where the Coda label would normally be. The D.C. instructions refer to the segno.

repeat-dc-al-segno.ly

[image of music]

A \repeat segno with a single alternative ending that is used for all volte receives a volta bracket rather than a coda sign because there is no material to skip. The bracket hooks down at the D.C..

The bracket communicates the return count, so the return count is omitted from the D.C. instruction to avoid redundancy.

repeat-dc-one-alternative.ly

[image of music]

This tests simple D.C. form with a segno following, and how it unfolds.

repeat-dc-then-ds.ly

[image of music]

This tests simple D.C. form with a rehearsal mark following.

repeat-dc-then-rehearsal-mark.ly

[image of music]

This tests simple D.C. form with a section label following.

repeat-dc-then-section-label.ly

[image of music]

Where a D.C. or D.S. instruction is not aligned on a measure boundary, the bar line defined by underlyingRepeatBarType appears by default. In this case, the D.C. should have a normal bar line and the D.S. should have a dotted bar line.

repeat-dc-unaligned.ly

[image of music]

When jumps to different targets occur simultaneously, LilyPond ignores one and issues a warning. Either a D.C. or a D.S. instruction, but not both, is expected. Unfolding is not affected: this case unfolds to EGGEGG.

repeat-dc-v-ds.ly

[image of music]

By default, \fine does not create a Fine instruction at the written end of the music, but this can be changed with the finalFineTextVisibility context property. There is no warning when a simultaneous D.C. instruction must appear there.

repeat-dc-v-fine-end-visible.ly

[image of music]

By default, \fine does not create a Fine instruction at the written end of the music, so there is no conflict when a simultaneous D.C. instruction must appear there.

repeat-dc-v-fine-end.ly

[image of music]

When events creating Fine and D.C. occur simultaneously, both indications are printed. This use case is not valued, but it is included in the regression test suite for robustness and difference detection.

repeat-dc-v-fine.ly

[image of music]

This tests D.S. al Coda form and how it unfolds.

repeat-ds-al-coda.ly

[image of music]

This tests D.S. al Fine form and how it unfolds.

repeat-ds-al-fine.ly

[image of music]

Setting segnoStyle to bar-line suppresses the first segno mark and causes a D.S. instruction to say simply D.S. without the mark. The second segno mark does appear and the corresponding D.S. instruction includes it.

repeat-ds-bar-line.ly

[image of music]

If the body of a segno repeat is empty, the result might be ugly, but it does not manifestly contradict the input. The margin labels show the expected note performance sequence.

repeat-ds-body-empty.ly

[image of music]

The format of D.S. and related instructions can be customized by overriding the dalSegnoTextFormatter context property. The line should end with the instruction A SIGNO.

repeat-ds-formatter.ly

[image of music]

Segno and coda marks created automatically by \repeat segno can be manually overridden with \segnoMark and \codaMark. A double segno and double coda sign should appear.

repeat-ds-mark-override.ly

[image of music]

When a D.C. or D.S. instruction is to be performed more than once, the default dalSegnoTextFormatter includes the count in the instruction. In this case, the D.C. instruction should indicate returning thrice and the D.S. instruction should indicate returning twice.

repeat-ds-return-count.ly

[image of music]

This tests mark formatting and placement for three sequential \repeat segno sections, each with three alternative endings, with some used for multiple volte.

repeat-ds-torture.ly

[image of music]

Repeat constructs without alternatives can be abbreviated using \etc .

repeat-etc.ly

[image of music]

Across linebreaks, the left edge of a first and second alternative bracket should be equal.

repeat-line-break.ly

[image of music]

Percent repeat counters can be shown at regular intervals by setting repeatCountVisibility.

repeat-percent-count-visibility.ly

[image of music]

Percent repeats get incremental numbers when countPercentRepeats is set, to indicate the repeat counts, but only if there are more than two repeats.

repeat-percent-count.ly

[image of music]

Percent repeats are also centered when there is a grace note in a parallel staff.

repeat-percent-grace.ly

[image of music]

Isolated percent-repeat signs can be printed.

repeat-percent-isolated.ly

[image of music]

The positioning of dots and slashes in percent repeat glyphs can be altered using dot-negative-kern and slash-negative-kern.

repeat-percent-kerning.ly

[image of music]

Percent repeats are not skipped, even when skipBars is set.

repeat-percent-skipbars.ly

[image of music]

Slash and percent signs are correctly scaled at different staff sizes.

repeat-percent-staff-size.ly

[image of music]

Measure repeats may be nested with beat repeats.

repeat-percent.ly

[image of music]

Alternative endings are not expected in ancient music. Here, the signum repetitionis resembles a modern repeat sign rather than telling the number of times the alternative is performed.

repeat-petrucci-alternatives.ly

[image of music]

This test demonstrates an ancient repeat sign in the Petrucci style, but with measure bar lines enabled. A single bar line should follow each repeat sign.

repeat-petrucci-with-measure-bar-lines.ly

[image of music]

This test demonstrates an ancient repeat sign in the Petrucci style. The sign consists of 1 to 4 short strokes between repeat dots, with the number of strokes indicating the number of times the preceding section is to be performed. The number of strokes is determined by the argument to \repeat volta, and a count higher than 4 falls back on a modern-looking sign with two long strokes. Despite appearances, these repeat signs are not bar lines.

A double bar line should follow the first note. A repeat sign should follow each following note: modern, 4 strokes, 3 strokes, 2 strokes, 1 stroke.

repeat-petrucci.ly

[image of music]

This piece consists of three consecutive sections using \repeat segno 1. Because of the count, no repeat notation should appear.

repeat-segno-count-one.ly

[image of music]

This tests a \repeat segno inside and at the end of a \repeat volta. The music unfolds to ABCBD ABCBD

repeat-segno-in-volta-end.ly

[image of music]

This tests a \repeat segno inside and in the middle of a \repeat volta. The music unfolds to ABCBDE ABCBDE.

repeat-segno-in-volta-middle.ly

[image of music]

This tests a \repeat segno inside and at the start of a \repeat volta. The music unfolds to A BCBDE BCBDE.

repeat-segno-in-volta-start.ly

[image of music]

The two dots of a repeat sign should be symmetric to the staff center and avoid staff lines even for exotic staves. Test set-global-staff size 10 (with layout-set-staff-size).

repeat-sign-global-size10.ly

[image of music]

The two dots of a repeat sign should be symmetric to the staff center and avoid staff lines even for exotic staves. Test set-global-staff size 30 (with layout-set-staff-size).

repeat-sign-global-size30.ly

[image of music]

The two dots of a repeat sign should be symmetric to the staff center and avoid staff lines even for exotic staves. Test set-global-staff size 10 (with layout-set-staff-size).

repeat-sign-global-size5.ly

[image of music]

The two dots of a repeat sign should be symmetric to the staff center and avoid staff lines even for exotic staves. Test layout-set-staff-size.

repeat-sign-layout-size.ly

[image of music]

The two dots of a repeat sign should be symmetric to the staff center and avoid staff lines even for exotic staves.

repeat-sign.ly

[image of music]

Beat repeats for patterns containing mixed durations use a double percent symbol.

repeat-slash-mixed.ly

[image of music]

Beat repeats for patterns containing identical durations shorter than an eighth note use multiple slashes.

repeat-slash-multi.ly

[image of music]

Within a bar, beat repeats denote that a music snippet should be played again.

repeat-slash.ly

[image of music]

\repeatTie ties should also work on individual notes of a chord.

repeat-tie-chords.ly

[image of music]

A \repeatTie may be parenthesized.

repeat-tie-parenthesize.ly

[image of music]

Repeat ties are only connected on the right side to a note head.

repeat-tie.ly

[image of music]

Each of the staves here should have four tremolo beams.

repeat-tremolo-beams.ly

[image of music]

Tremolos work with chord repetitions.

repeat-tremolo-chord-rep.ly

[image of music]

Dots are added to tremolo notes if the durations involved require them.

repeat-tremolo-dots.ly

[image of music]

A tremolo repeat containing only one note (no sequential music) shall not be scaled. An articulation or dynamic sign on the note should not confuse lilypond.

repeat-tremolo-one-note-articulation.ly

[image of music]

A tremolo can have more than two notes. Also check that linebreaks between tremolos still work and that empty tremolos don’t crash.

repeat-tremolo-three-notes.ly

[image of music]

Volta repeats may be unfolded through the music function \unfoldRepeats.

repeat-unfold-all.ly

[image of music]

\repeat unfold 1 unfolds according to the count. This piece has one measure and \unfoldRepeats does not change that.

repeat-unfold-count-one.ly

[image of music]

The music function \unfoldRepeats can take an optional argument-list specifying which type(s) of repeated music has to be unfolded.

repeat-unfold-partial.ly

[image of music]

Unfolding tremolo repeats. All fragments fill one measure with 16th notes exactly.

repeat-unfold-tremolo.ly

[image of music]

LilyPond has two modes for repeats: unfolded and semi-unfolded. Unfolded repeats are fully written out. Semi unfolded repeats have the body written and all alternatives sequentially. If the number of alternatives is larger than the repeat count, the excess alternatives are ignored. If the number of alternatives is smaller, the first alternative is multiplied to get to the number of repeats.

Unfolded behavior:

repeat-unfold.ly

[image of music]

If the body of a volta repeat is empty, the alternatives are still rendered with the expected volta notation.

repeat-volta-body-empty.ly

[image of music]

If the body of a volta repeat is only a grace note, it is still engraved as expected.

repeat-volta-body-grace.ly

[image of music]

This test covers a volta repeat as top-level music with the repeat body being simultaneous music.

repeat-volta-body-simultaneous.ly

[image of music]

This piece consists of three consecutive sections using \repeat volta 1. Setting printTrivialVoltaRepeats notates bars and a bracket anyway, but the piece still unfolds according to the repeat count.

repeat-volta-count-one-printed.ly

[image of music]

This piece consists of three consecutive sections using \repeat volta 1. Because of the count, no repeat notation should appear.

repeat-volta-count-one.ly

[image of music]

This tests a \repeat volta inside and at the end of a \repeat segno. The music unfolds to ABCBD ABCBD

repeat-volta-in-segno-end.ly

[image of music]

This tests a \repeat volta inside and in the middle of a \repeat segno. The music unfolds to ABCBDE ABCBDE.

repeat-volta-in-segno-middle.ly

[image of music]

This tests a \repeat volta inside and at the start of a \repeat segno. The music unfolds to A BCBDE BCBDE.

repeat-volta-in-segno-start.ly

[image of music]

A piece beginning with grace notes followed by a volta repeat has an opening repeat bar in the expected position.

repeat-volta-initial-grace.ly

[image of music]

A single \alternative is a way to indicate a repeat count when there is no variation.

repeat-volta-one-alternative.ly

[image of music]

When too few alternatives are present, the first alternative is repeated, by printing a range for the 1st repeat.

repeat-volta-skip-alternatives.ly

[image of music]

\volta assigns bracket labels without reordering alternatives. A final alternative that is not exclusive to the final volta ends with a repeat bar.

repeat-volta-specified-alternatives.ly

[image of music]

\fine ends the piece when it is found outside folded repeats.

repeat-volta-with-fine.ly

[image of music]

Volta (Semi folded) behavior. Voltas can start on non-bar line moments. If they don’t bar lines should still be shown.

repeat-volta.ly

[image of music]

Rests avoid notes. Each rest is moved in the direction of the stems in its voice. Rests may overlap other rests in voices with the same stem direction, in which case a warning is given, but is suppressed if the rest has a pitch.

rest-avoid-note.ly

[image of music]

Beam/rest collision resolution and normal rest/note collisions can be combined.

rest-collision-beam-note.ly

[image of music]

Rests under beams are moved by whole staff spaces.

rest-collision-beam-quantized.ly

[image of music]

Beam/rest collision takes offset due to Rest #'direction into account properly.

rest-collision-beam-restdir.ly

[image of music]

Rests under beams are shifted upon collision.

rest-collision-beam.ly

[image of music]

Vertical rest positions in a multi-voice staff should obey the duration of notes; this is, they shouldn’t return to a default position too early.

rest-collision-note-duration.ly

[image of music]

Rests should not collide with beams, stems and noteheads. Rests may be under beams. Rests should be move by integral number of spaces inside the staff, and by half spaces outside. Notice that the half and whole rests just outside the staff get ledger lines in different cases.

rest-collision.ly

[image of music]

Dots of rests should follow the rest positions.

rest-dot-position.ly

[image of music]

Breve, longa, and maxima rests should hang down from staff lines in one line staves, different staff space and font size.

rest-hanging-breve.ly

[image of music]

Breve, whole and half rests moving outside the staff should get ledger lines.

rest-ledger.ly

[image of music]

In rest-note collisions, the rest moves in discrete steps, and inside the staff, it moves in whole staff spaces.

rest-note-collision.ly

[image of music]

half rests should lie on a staff line, whole rests should hang from a staff line by default even for non-standard staves, except when the position is set by pitch.

rest-on-nonstandard-staff.ly

[image of music]

Rests can have pitches – these will be affected by transposition and relativization. If a rest has a pitch, rest/rest and beam/rest collision resolving will leave it alone.

rest-pitch.ly

[image of music]

Pitched rests under beams.

rest-pitched-beam.ly

[image of music]

In polyphonic situations, rests are moved according to their direction even if there is no opposite note or rest. The amount in staff-positions is set by voiced-position.

rest-polyphonic.ly

[image of music]

This shows the one-voice rest positions for various standard and tab staves.

rest-positioning-one-voice.ly

[image of music]

This shows the two-voice rest positions for various standard and tab staves.

rest-positioning-two-voices.ly

[image of music]

There is a big variety of rests. Note that the dot of 8th, 16th and 32nd rests rest should be next to the top of the rest. All rests except the whole rest are centered on the middle staff line.

rest.ly

[image of music]

\retrograde can deal with crescendo and decrescendo as long as they are properly paired with \endcr/\! and \enddecr. Direction modifiers on slurs like ^( need to be repeated as ^) at the end. Ties and glissandi work mostly (in-chord ties are turned into ordinary per-chord/note ties, however).

retrograde.ly

[image of music]

\once \revert can be used for reverting a property once rather than permanently.

revert-once.ly

[image of music]

When an unpitched duration is parsed as a rhythmic event, it sets the default duration of the following note events. This happens even when it is the argument of a music function. In these examples, notes with an explicit duration are indicated with an accent and the following notes have to have the same duration.

rhythm-sets-default-duration.ly

[image of music]

Durations without pitches are placed into note events without pitch information. Those are directly useful in RhythmicStaff.

rhythmic-sequence.ly

[image of music]

In rhythmic staves stems should go up, and bar lines have the size for a 5 line staff. The whole rest hangs from the rhythmic staff.

rhythmic-staff.ly

[image of music]

This should produce an SATB score on two staves with 5 verses and piano accompaniment.

satb-template-on-two-staves-with-verses.ly

[image of music]

Soprano and tenor voices may be omitted without error, even when TwoVoicesPerStaff is specified and Alto and Bass lyrics are provided.

satb-template-soprano-and-tenor-may-be-omitted.ly

[image of music]

Instrument names and short instrument names can be changed when using the satb built-in template.

satb-template-with-changed-instrument-names.ly

[image of music]

This should produce an SATB score with piano accompaniment, with four voices in the first system, unison women voices with descant in the second system and unison women and unison men voices in the third system.

satb-template-with-men-women-and-descant.ly

[image of music]

Scores can be generated with scheme, too, and inserted into the current book(part). Generated and explicit scores can be mixed, the header informations from top- and booklevel stack correctly.

scheme-book-scores.ly

[image of music]

Scheme engravers may be instantiated, with instance-scoped slots, by defining a 1 argument procedure which shall return the engraver definition as an alist, with the private slots defined in a closure. The argument procedure argument is the context where the engraver is instantiated.

scheme-engraver-instance.ly

[image of music]

\consists can take a scheme alist as arguments, which should be functions, which will be invoked as engraver functions.

scheme-engraver.ly

[image of music]

The #@ and $@ operators splice a list, returning multiple values to the parser. This is equivalent to returning the multiple values directly using values.

scheme-list-splicing.ly

[image of music]

Use define-event-class, scheme engraver methods, and grob creation methods to create a fully functional text spanner in scheme.

scheme-text-spanner.ly

[image of music]

Console output should indicate that translators created with make-translator are available in ‘\layout’ and ‘\midi’, engravers created with make-engraver just in ‘\layout’, and performers created with make-performer just in ‘\midi’.

scheme-translators.ly

[image of music]

Ensures the zombie check actually works. This should print a log message ’object should be dead’

scheme-zombies.ly

[image of music]

The \score-lines markup returns individual score lines as stencils rather than a single stencil. Calling a function like \rotate on \score-lines rotates the lines individually, as contrasted with rotating an entire \score markup.

score-lines.ly

[image of music]

It works to set titling fields to ##f on score level while they have been defined to markup values in the global header.

score-suppress-title.ly

[image of music]

Markup texts are rendered above or below a score.

score-text.ly

[image of music]

Scripts use skylines with accurate boxes to avoid accidentals.

script-accidental-collision.ly

[image of music]

Scripts on chords with seconds remain centered on the extremal note head

script-center-seconds.ly

[image of music]

Scripts are put on the utmost head, so they are positioned correctly when there are collisions.

script-collision.ly

[image of music]

New entries may be added to the default-script-alist. They may contain a setting for staff-position for an offset in Y-axis direction, if used horizontally. It is possible to customize Y-offset or staff-position by override or tweak. The here defined segno-coda articulation prints a segno bottom/left and a coda top/right. The horizontal segno should be printed on second, third and fourth staff-line. The horizontal coda at second staff-line.

script-custom-definition.ly

[image of music]

Horizontal scripts don’t have avoid-slur set.

script-horizontal-slur.ly

[image of music]

Omitted scripts on skips do not cause crashes.

script-no-stencil.ly

[image of music]

The horizontal placement of staccato dots above an upstem or below a downstem note differs from the placement of other scripts in that different positioning is used when the dot is alone and when it is part of a compound articulation. The property toward-stem-shift-in-column ensures good default positioning of the staccato (see first measure below), and allows precise horizontal control of a column containing a staccato and of the staccato within it (second measure). (0.0 means centered on the note head, 1.0 means centered on the stem.)

script-shift-staccato.ly

[image of music]

The toward-stem-shift property controls the precise horizontal location of scripts that are placed above an upstem or below a downstem note (0.0 means centered on the note head, 1.0 means centered on the stem).

script-shift.ly

[image of music]

Scripts on skips are supported.

script-skip.ly

[image of music]

horizontal scripts are ordered, so they do not overlap. The order may be set with script-priority.

The scripts should not be folded under the time signature.

script-stack-horizontal.ly

[image of music]

Scripts can be stacked. The order is determined by a priority field, but when objects have the same priority, the input order determines the order. Objects specified first are closest to the note.

script-stack-order.ly

[image of music]

The vertical stacking order of scripts goes from least to most technical, where the least technical scripts are closest to the note: articulation, flageolet, fingering, right-hand fingering, string number, fermata, bowing, text script.

script-stack-order1.ly

[image of music]

Scripts may be stacked.

script-stacked.ly

[image of music]

Scripts avoid stem tremolos even if there is no visible stem.

script-stem-tremolo.ly

[image of music]

Scripts avoid ties.

script-tie-collision.ly

[image of music]

Section labels appear at the top of the system, appear at the beginning of a line at a break, remain visible at the end of the score, and can be styled via the SectionLabel grob.

section-label-style.ly

[image of music]

\segnoMark \default at the beginning of the score does not create a mark. A single segno should appear at the beginning of the second measure and a double segno should appear at the end.

segno-mark-begin-score-default.ly

[image of music]

\segnoMark 1 at the beginning of the score creates a visible mark. A single segno should appear at the beginning of the measure and a double segno should appear at the end.

segno-mark-begin-score-specific.ly

[image of music]

A segno at a line break appears at the beginning of the line.

segno-mark-break.ly

[image of music]

Where a segno mark is not aligned on a measure boundary, the bar line defined by underlyingRepeatBarType appears by default. In this case, the single segno should have a normal bar line and the double segno should have a dotted bar line.

segno-mark-unaligned.ly

[image of music]

Segni are printed as marks or bar lines according to the segnoStyle context property. The mark style, which is the default, yields marks only. When the style is set to bar-line, the default segnoMarkFormatter skips the mark for segno 1, but allows marks on later segni to eliminate ambiguity. The user can override the segno formatter with a rehearsal-mark formatter. Rehearsal marks and segni are sequenced independently.

segno-style.ly

[image of music]

Grobs using ly:self-alignment-interface::aligned-on-x-parent and ly:self-alignment-interface::aligned-on-y-parent callbacks support separate alignments for self and parent.

self-alignment-and-parent-alignment.ly

[image of music]

Cross-staff RepeatTie and LaissezVibrerTie do not trigger programming errors for circular dependencies in direction.

semi-tie-cross-staff.ly

[image of music]

Semi tie directions may be forced from the input.

semi-tie-manual-direction.ly

[image of music]

\once \set should change a context property value for just one timestep and then return to the previous value.

set-once.ly

[image of music]

In addition to Slur, the music function \shape works with PhrasingSlur, Tie, LaissezVibrerTie, and RepeatTie. Each is shown below, first unmodified and then (in blue) after application of the function.

shape-other-curves.ly

[image of music]

The control points of a broken or unbroken slur may be offset by \shape. The blue slurs are modified from the default slurs shown first.

shape-slurs.ly

[image of music]

\shiftDurations can use negative dot values without causing a crash.

shift-durations-negative-dots.ly

[image of music]

A number of shorthands like (, ), |, [, ], ~, \(, \) and others can be redefined like normal commands. ly/declarations-init.ly serves as a regtest for a number of them. This test just demonstrates replacing ( and ) with melismata commands which are not articulations.

shorthands.ly

[image of music]

The show-horizontal-skylines and show-horizontal-skylines properties display skylines to assist debugging.

show-skylines.ly

[image of music]

The space types shrink-space and semi-shrink-space only shrink.

shrink-space.ly

[image of music]

Different text styles are used for various purposes.

size11.ly

[image of music]

Different text styles are used for various purposes.

size13.ly

[image of music]

Different text styles are used for various purposes.

size16.ly

[image of music]

Different text styles are used for various purposes.

size20.ly

[image of music]

Different text styles are used for various purposes.

size23.ly

[image of music]

Different text styles are used for various purposes.

size26.ly

[image of music]

\skip can skip over music. The expected output is two A notes separated by two empty measures.

skip-music.ly

[image of music]

skip-of-length and mmrest-of-length create skips and rests that last as long as their arguments.

skip-of-length.ly

[image of music]

A score with skipTypesetting set for the whole score will not segfault.

skiptypesetting-all-true-midi.ly

[image of music]

A score with skipTypesetting set for the whole score will not segfault.

skiptypesetting-all-true.ly

[image of music]

skipTypesetting doesn’t affect bar checks.

skiptypesetting-bar-check.ly

[image of music]

After a cut made with skipTypesetting, a change clef may appear even if one would not normally appear there. The requirement is loose: it must simply be clear which clef the following music requires. The expected clef of the final measure appears in the margin.

skiptypesetting-clef.ly

[image of music]

When skipTypesetting is set during a skipBars-induced MultiMeasureRest spanner, no segfault occurs.

skiptypesetting-multimeasurerest.ly

[image of music]

showFirstLength and showLastLength may be set at the same time; both the beginning and the end of the score will be printed.

skiptypesetting-show-first-and-last.ly

[image of music]

showFirstLength will only show the first bit of a score

skiptypesetting-show-first.ly

[image of music]

showLastLength will only show the last bit of a score

skiptypesetting-show-last.ly

[image of music]

Tuplet brackets are also skipped with skipTypesetting.

skiptypesetting-tuplet.ly

[image of music]

Skylines of boxes with and without rounded corners reflect the actual box outline even if rotated. Skylines of ellipses are stable when rotated.

skyline-boxes-ellipses.ly

[image of music]

-ddebug-skyline draws the outline of the skyline used.

skyline-debug.ly

[image of music]

If no outline is available (eg. for embedded PS), the bounding box is used as a fallback.

skyline-embedded-ps.ly

[image of music]

Do not crash on handling round-filled-box with infinite extents.

skyline-empty-box.ly

[image of music]

Skylines reflect grob rotation.

skyline-grob-rotation.ly

[image of music]

The skyline-horizontal-padding property can be set for System in order to keep systems from being spaced too closely together. In this example, the low notes from a system should not be interleaved with the high notes from the next system.

skyline-horizontal-padding.ly

[image of music]

Test skyline merging. The red and blue lines are two skylines with direction UP, represented with the X axis as horizon axis. The black line is the merged skyline. At every point on the X axis, the black line should be at the maximum between the height of the red line and the height of the blue line at that point.

skyline-merging.ly

[image of music]

The Script grobs should follow the descending melody line, even though the NoteHead stencils are point stencils. The Stem_engraver is removed so that the only side-support-element is the NoteHead.

skyline-point-extent.ly

[image of music]

The skylines of side-positioned objects can be removed, without causing crashes.

skyline-removed.ly

[image of music]

Skylines cover all segments of slurs.

skyline-slur-segments.ly

[image of music]

Grobs that have outside-staff-priority set are positioned using a skyline algorithm so that they don’t collide with other objects.

skyline-vertical-placement.ly

[image of music]

We use a skyline algorithm to determine the distance to the next system instead of relying only on bounding boxes. This keeps gaps between systems more uniform.

skyline-vertical-spacing.ly

[image of music]

Slashed beams work with cross-staff beams.

slashed-beam-cross-staff.ly

[image of music]

Printing slashed beams is the default for \slashedGrace.

slashed-beam-grace.ly

[image of music]

Slashed beams work nicely with different sizes caused by \magnifyStaff or layout-set-staff-size.

slashed-beam-staff-size.ly

[image of music]

A slash may be added to a beam using beam::slashed-stencil. Relying on the details-subproperty slash-side the slash is added at left (default) or at right side of the beam.

slashed-beam.ly

[image of music]

Slurs handle avoid objects better.

slur-avoid.ly

[image of music]

Across line breaks, slurs behave nicely. On the left, they extend to just after the preferatory matter, and on the right to the end of the staff. A slur should follow the same vertical direction it would have in unbroken state.

slur-broken-trend.ly

[image of music]

Slurs avoid clefs, but don’t avoid bar lines.

slur-clef.ly

[image of music]

Slurs that depend on a cross-staff beam are not calculated until after line-breaking, and after inside-going articulations have been placed.

slur-cross-staff-beam.ly

[image of music]

Slurs behave decently when broken across a linebreak.

slur-cross-staff.ly

[image of music]

The appearance of slurs may be changed from solid to dotted or dashed.

slur-dash.ly

[image of music]

Slurs avoid dots.

slur-dot-collision.ly

[image of music]

Slurs on dotted notes should have a similar distance to the note heads as slurs on non-dotted notes if this does not lead to a collision.

slur-dot-distance.ly

[image of music]

Slurs should not get confused by augmentation dots. With a lot of dots, the problems becomes more visible.

slur-dots.ly

[image of music]

Some composers use slurs both above and below chords. This can be typeset by setting doubleSlurs

slur-double.ly

[image of music]

Dynamics avoid collision with slur.

slur-dynamics.ly

[image of music]

Extreme slurs are scaled to fit the pattern, but only symmetrically. Asymmetric slurs are created by setting eccentricity.

slur-extreme.ly

[image of music]

Slurs take flag extents into account.

slur-flag.ly

[image of music]

Appoggiatura and acciaccaturas use a different slur than the default, so they produce a nested slur without warnings.

slur-grace.ly

[image of music]

Slur shaping is not adapted to accommodate objects towards the edges of slur. Said objects are thus ignored, which should make the slur in this regtest flat. Objects towards the edges are not, however, ignored in the slur scoring.

slur-height-capping.ly

[image of music]

Specifying inspect-quants, will print out demerit scores for the given configuration. Here, there are demerits for slur slope going to melody slope, and the slur ending far from the right edge.

slur-inspect-quants.ly

[image of music]

Setting positions overrides the automatic positioning of the slur. It selects the slur configuration closest to the given pair.

slur-manual.ly

[image of music]

An additional opening slur during a running slur should be ignored (and a warning printed), but never influence the slur’s extents.

slur-multiple-linebreak.ly

[image of music]

LilyPond does not support multiple concurrent slurs with the parentheses syntax. In this case, warnings will be given and the nested slur will not be generated. However, one can can create a second slur with a different spanner-id.

slur-multiple.ly

[image of music]

Slurs should look nice and symmetric. The curvature may increase only to avoid noteheads, and as little as possible. Slurs never run through noteheads or stems.

slur-nice.ly

[image of music]

The slur between the stemless notes should begin and end in the same spaces as the slur between the stemmed notes.

slur-no-stem.ly

[image of music]

Rests don’t change slur direction (default is down).

slur-rest-direction.ly

[image of music]

Slurs may be placed over rests. The slur will avoid colliding with the rests.

slur-rest.ly

[image of music]

Slur formatting is based on scoring. A large number of slurs are generated. Each esthetic aspect gets demerits, the best configuration (with least demerits) wins. This must be tested in one big file, since changing one score parameter for one situation may affect several other situations.

Tunable parameters are in scm/slur.scm.

slur-scoring.ly

[image of music]

Slurs avoid scripts with avoid-slur set to inside, scripts avoid slurs with avoid-slur set to around. Slurs and scripts keep a distance of slur-padding.

slur-script-inside.ly

[image of music]

A slur avoids collisions with scripts, which are placed either inside or outside the slur, depending on the script. The slur responds appropriately if a script is moved.

slur-script.ly

[image of music]

A slur’s shift region is automatically made higher to accommodate extra encompass elements.

slur-shift-region.ly

[image of music]

Slurs avoid StrokeFinger grobs with avoid-slur set to inside; StrokeFinger grobs avoid slurs with avoid-slur set to around (the default). Slurs and StrokeFinger grobs keep a distance as set by the slur-padding property.

slur-stroke-fingering-inside.ly

[image of music]

Symmetric figures should lead to symmetric slurs.

slur-symmetry.ly

[image of music]

Slurs and ties should never share extremal control points.

slur-tie-control-points.ly

[image of music]

The attachment point for strongly sloped slurs is shifted horizontally slightly. Without this correction, slurs will point into one note head, and point over another note head.

slur-tilt.ly

[image of music]

TupletNumber grobs are always inside slurs. This may not work if the slur starts after the tuplet.

slur-tuplet.ly

[image of music]

Slurs do not force grobs with outside-staff-priority too high.

slur-vertical-skylines.ly

[image of music]

Outside staff callbacks that no longer apply to grobs because they are outside the X boundary of a slur should terminate early. The example below should generate no warnings about Bezier curves and there should be no change in StrokeFinger position between the first and second examples.

slur-vestigial-outside-staff-callback.ly

[image of music]

\smallCaps works on an arbitrary markup argument.

smallcaps-markup.ly

[image of music]

The output should include a clef, key signature, and time signature.

spacer-no-notes.ly

[image of music]

Accidentals don’t collide with shifted-down rests.

spacing-accidental-rest.ly

[image of music]

Accidentals in different staves do not affect the spacing of the eighth notes here.

spacing-accidental-staffs.ly

[image of music]

Accidentals do not influence the amount of stretchable space. The accidental does add a little non-stretchable space.

spacing-accidental-stretch.ly

[image of music]

Horizontal spacing works as expected on tied notes with accidentals. No space is reserved for accidentals that end up not being printed, but accidentals that are printed don’t collide with anything.

spacing-accidental-tie.ly

[image of music]

Accidentals sticking out to the left of a note will take a little more space, but only if the spacing is tight.

spacing-accidental.ly

[image of music]

An accidental following a bar gets space so the left edge of the acc is at 0.3 staff space from the bar line

spacing-bar-accidental.ly

[image of music]

An arpeggio following a bar gets space

spacing-bar-arpeggio.ly

[image of music]

Downstem notes following a bar line are printed with some extra space. This is an optical correction similar to juxtaposed stems.

The bar upstem should be approx 1.1 staff space, the bar downstem 1.3 to 1.5 staff space.

spacing-bar-stem.ly

[image of music]

Notes that fill a whole measure are preceded by extra space.

spacing-bar-whole-measure.ly

[image of music]

Clef changes at the start of a line get much more space than clef changes halfway the line.

spacing-clef-first-note.ly

[image of music]

If right hand stems have accidentals, optical spacing correction is still applied, but only if the stem directions are different.

spacing-correction-accidentals.ly

[image of music]

Empty bar lines do not affect spacing.

spacing-empty-bar.ly

[image of music]

Broken engraving of a bar at the end of a line does not upset the space following rests and notes.

spacing-end-of-line.ly

[image of music]

A voicelet (a very short voice to get polyphonic chords correct) should not confuse the spacing engine.

spacing-ended-voice.ly

[image of music]

Clefs are also folded under cross staff constructs.

spacing-folded-clef-cross-staff.ly

[image of music]

A clef can be folded below notes in a different staff, if this does not disrupt the flow of the notes.

spacing-folded-clef.ly

[image of music]

A clef can be folded below notes in a different staff, if there is space enough. With Paper_column stencil callbacks we can show where columns are in the score.

spacing-folded-clef2.ly

[image of music]

Voices that go back and forth between staves do not confuse the spacing engine.

spacing-folded-clef3.ly

[image of music]

Spacing uses the duration of the notes, but disregards grace notes for this. In this example, the 8ths around the grace are spaced exactly as the other 8th notes.

spacing-grace-duration.ly

[image of music]

Grace note runs have their own spacing variables in Score.GraceSpacing. So differing grace note lengths inside a run are spaced accordingly.

spacing-grace.ly

[image of music]

Skyline horizontal spacing may fold non-adjacent columns together, but they still do not collide. In this case, the arpeggio and the bar line do not collide.

spacing-horizontal-skyline-grace.ly

[image of music]

accidentals may be folded under preceding notes.

spacing-horizontal-skyline.ly

[image of music]

Spacing corrections for kneed beams still work when compression is involved.

spacing-knee-compressed.ly

[image of music]

For knees, the spacing correction is such that the stems are put at regular distances. This effect takes into account the width of the note heads and the thickness of the stem.

spacing-knee.ly

[image of music]

Even in case of incorrect contexts (eg. shortlived contexts) that break linking of columns through spacing wishes, strict-note-spacing defaults to a robust solution. This test passes if it does not seg fault; instead it should produce three programming error messages. Note that, in tight music with strict note spacing, grace notes will collide with normal notes. This is expected.

spacing-loose-grace-error.ly

[image of music]

If a floating grace spacing section attaches to a note across a line break, it gets attached to the end of line.

spacing-loose-grace-linebreak.ly

[image of music]

With strict-grace-spacing, grace notes don’t influence spacing.

spacing-loose-grace.ly

[image of music]

Loose columns (here, the treble clef) are spaced correctly in polyphonic music.

spacing-loose-polyphony.ly

[image of music]

Width of marks does not affect spacing.

spacing-mark-width.ly

[image of music]

Horizontal spacing is bounded by the current measure length. This means that the 3/8 setting does not affect the whole rest spacing.

spacing-measure-length.ly

[image of music]

Concurrent tuplets should be equidistant on all staves.

spacing-multi-tuplet.ly

[image of music]

In the absence of NoteSpacings, wide objects still get extra space. In this case, the slash before the bar line gets a little more space.

spacing-no-note.ly

[image of music]

The spacing engine avoids collisions between non-adjacent columns.

spacing-non-adjacent-columns1.ly

[image of music]

The spacing engine avoids collisions between non-adjacent columns.

spacing-non-adjacent-columns2.ly

[image of music]

The spacing engine avoids collisions between non-adjacent columns.

spacing-non-adjacent-columns3.ly

[image of music]

The flags of 8th notes take some space, but not too much: the space following a flag is less than the space following a beamed 8th head.

spacing-note-flags.ly

[image of music]

In packed mode, pack notes as tight as possible. This makes sense mostly in combination with ragged-right mode: the notes are then printed at minimum distance. This is mostly useful for ancient notation, but may also be useful for some flavours of contemporary music. If not in ragged-right mode, lily will pack as many bars of music as possible into a line, but the line will then be stretched to fill the whole linewidth.

spacing-packed.ly

[image of music]

For spacing-pair, when an item matching a break align symbol is omitted, the alignment falls back on later break align symbols in the list. In this test, the measure counter should be centered using the right edge of the key signature.

spacing-pair-omitted-item.ly

[image of music]

The spacing-pair property takes the combined extents of all items having the given break align symbol into account. In this test, the centering of the measure counter should visibly happen with the left point being on the right of the wide key signature. The alignment of the measure counter should be the same for both scores.

spacing-pair-several-matching-items.ly

[image of music]

The space after a paper column can be increased by overriding the padding property.

spacing-paper-column-padding.ly

[image of music]

Proportional notation can be created by setting proportionalNotationDuration. Notes will be spaced proportional to the distance for the given duration.

spacing-proportional.ly

[image of music]

If ragged-last is set, the systems are broken similar to paragraph formatting in text: the last line is unjustified.

spacing-ragged-last.ly

[image of music]

Rests get a little less space, since they are narrower. However, the quarter rest in feta font is relatively wide, causing this effect to be very small.

spacing-rest.ly

[image of music]

New sections for spacing can be started with \newSpacingSection. In this example, a section is started at the 4/16, and a 16th in the second section takes as much space as a 8th in first section.

spacing-section.ly

[image of music]

Notes that are shorter than the common shortest note get a space (i.e. without the space needed for the note) proportional to their duration. So, the 16th notes get 1/2 of the space of an eighth note. The total distance for a 16th (which includes note head) is 3/4 of the eighth note.

spacing-short-notes.ly

[image of music]

If space-to-barline is false, we measure the space between the note and the start of the clef. If space-to-barline is true, we measure the space between the note and the start of the bar line.

spacing-space-to-barline.ly

[image of music]

Upstem notes before a bar line are printed with some extra space. This is an optical correction similar to juxtaposed stems.

spacing-stem-bar.ly

[image of music]

There are optical corrections to the spacing of stems. The overlap between two adjacent stems of different direction is used as a measure for how much to correct.

spacing-stem-direction.ly

[image of music]

For juxtaposed chords with the same direction, a slight optical correction is used. It is constant, and works only if two chords have no common head-positions range.

spacing-stem-same-direction.ly

[image of music]

LilyPond will space a line to prevent text sticking out of the right margin unless keep-inside-line is false for the relevant PaperColumn.

spacing-stick-out.ly

[image of music]

If strict-note-spacing is set, then spacing of notes is not influenced by bars and clefs half-way on the system. Rather, they are put just before the note that occurs at the same time. This may cause collisions.

spacing-strict-notespacing.ly

[image of music]

With strict-note-spacing spacing for grace notes (even multiple ones), is floating as well.

spacing-strict-spacing-grace.ly

[image of music]

An empty bar line does not confuse the spacing engine too much. The two scores should look approximately the same.

spacing-to-empty-barline.ly

[image of music]

Space from a normal note (or bar line) to a grace note is smaller than to a normal note.

spacing-to-grace.ly

[image of music]

Notes are spaced exactly according to durations, if uniform-stretching is set. Accidentals are ignored, and no optical-stem spacing is performed.

spacing-uniform-stretching.ly

[image of music]

The SpanBarStub grob takes care of horizontal spacing for SpanBar grobs. When the SpanBar is disallowed, objects in contexts that the span bar would have otherwise crossed align as if the span bar were not there.

span-bar-allow-span-bar.ly

[image of music]

Articulations on cross-staff stems do not collide with span bars.

span-bar-articulation.ly

[image of music]

This tests the calculation of the anchor point on a mensurstrich bar line.

The top staff has no span bar. A rehearsal mark should appear over an invisible bar line between the two notes.

The lower pair of staves has a span bar of exaggerated width. A rehearsal mark should appear centered over it.

span-bar-break-align-anchor.ly

[image of music]

A user-defined bar line with span bar #f does not disturb printing of compound bar lines. Using neither a string nor a boolean prints warnings, though does not abort. An empty string is supported as well.

The first three bar lines should look identical (no span bar).

span-bar-false.ly

[image of music]

Span bars can be turned on/off on a staff-by-staff basis.

span-bar-partial.ly

[image of music]

Because BarLine grobs take their extra-positioning-height from their neighbors via the pure-from-neighbor-interface, the left edge of an accidental should never fall to the left of the right edge of a bar line. This spacing should also take place when SpanBar grobs are present.

span-bar-spacing.ly

[image of music]

A user-defined bar line with annotated bar-type does not warn when span-bar is #t or a string literal that is equal to bar-type (including the annotation).

All bar lines should look the same.

span-bar-true.ly

[image of music]

Span bars are drawn only between staff bar lines. By setting bar lines to transparent, they are shown only between systems.

Setting SpanBar transparent removes the bar lines between systems.

span-bar.ly

[image of music]

The visibility of left-broken line spanners and hairpins which end on the first note (i.e., span no time between bounds) is controlled by the callback ly:spanner::kill-zero-spanned-time.

spanner-after-line-breaking.ly

[image of music]

Spanners align to musical grobs in paper columns, ignoring things like pedal marks.

spanner-alignment.ly

[image of music]

Spanners parts that extend beyond their parents are killed in case of line breaks.

spanner-break-beyond-parent.ly

[image of music]

The break-overshoot property sets the amount that a broken spanner ‘sticks out’ of its bounds.

For broken beams and broken tuplet brackets, the bounds are given by the prefatory matter on the left and/or the rightmost column on the right. For broken horizontal brackets, the bounds are the leftmost and/or rightmost columns; for measure spanners, the left and/or right edge of the staff.

spanner-break-overshoot.ly

[image of music]

Empty bounds on a line spanner do not cause LilyPond to get stuck in an infinite loop.

spanner-empty-bound.ly

[image of music]

This should produce a choral score with solo, descant, women, sop 1 and 2, sop, alto, alto 1 and 2, tenor 1 and 2, tenor, bass, bass 1 and 2, men and piano staves. Normally the various combinations would appear at different times in the score, not all at once.

ssaattbb-template-with-all-staves.ly

[image of music]

This should produce a choral score with solo, descant, women, sop divisi, sop and alto, alto divisi, tenor divisi, tenor and bass, bass divisi, men and piano staves. Normally the various combinations would appear at different times in the score, not all at once.

ssaattbb-template-with-all-voices-on-one-staff.ly

[image of music]

Instrument names and short instrument names can be changed when using the ssaattbb built-in template.

ssaattbb-template-with-changed-instrument-names.ly

[image of music]

This should produce an SSAATTBB score with piano accompaniment, with divisi soprano and tenor on single staves, alto one and alto two on separate staves and unison bass in the first system, then unison soprano and alto voices with descant in the second system and unison women and unison men voices in the third system.

ssaattbb-template-with-men-women-and-descant.ly

[image of music]

Some scripts must have quantized postions. VErtical position descend monotonously for a descending scale. The staccato dot is close to the notehead. If the head is in a space, then the dot is in the space next to it.

staccato-pos.ly

[image of music]

Adding a new staff at a line break doesn’t crash.

staff-add-at-linebreak.ly

[image of music]

Staves stay alive long enough to complete an automatic beam.

staff-change-autobeam.ly

[image of music]

When a BreathingSign is aligned as a 'staff-bar, staff lines extend through it, even if it is accompanied by a zero-width BarLine at the end of the line.

The output should show two identical staves. Between the notes should appear a finalis sign (like a double bar line) overlapping with a dotted bar line; this shows that BreathingSign and BarLine are aligned alike. At the end of the line should appear a finalis sign with the staff lines extending to its right side.

staff-extend-to-staff-bar.ly

[image of music]

Staves can be started and stopped at command.

staff-halfway.ly

[image of music]

When highlights are used in combination with ossia staves, a highlight only extends to include the ossia staff if it actually spans a portion of it, but not if it ends at the start of the ossia or if it starts at the end of the ossia.

staff-highlight-ossia.ly

[image of music]

Highlights can be used in RhythmicStaff. They extend vertically as far as bar lines do.

staff-highlight-rhythmicstaff.ly

[image of music]

This test exercises highlights spanning a set of rhythmic staves with different font sizes. At the bottom and at the top, the highlight should extend as far as the bar lines do.

staff-highlight-score-rhythmic-staves.ly

[image of music]

Highlights can be used in Score.

staff-highlight-score.ly

[image of music]

Highlights can be used in contexts at higher level than Staff.

staff-highlight-staffgroup.ly

[image of music]

This test shows highlights starting and ending on prefatory material in various situations.

staff-highlight-start-end.ly

[image of music]

The \staffHighlight command highlights a musical passage. A highlight is terminated by \stopStaffHighlight, by the start of another highlight, or by the end of the music.

staff-highlight.ly

[image of music]

When the vertical positions of ledger lines have been customized by setting the ledger-positions property of the StaffSymbol, and a dotted note falls on a ledger line, the dot is shifted up to avoid the ledger line (just as with uncustomized ledger lines).

staff-ledger-positions-dotted-notes.ly

[image of music]

The vertical positions of ledger lines may be customised by setting the ledger-positions property of the StaffSymbol. The given pattern is repeated. Bracketed groups are always shown together: either all or none are shown. Ledger lines can be set to appear sooner or later by setting the ledger-extra property.

staff-ledger-positions.ly

[image of music]

The vertical positions of staff lines may be specified individually, by setting the line-positions property of the StaffSymbol.

staff-line-positions.ly

[image of music]

Staves may be present in several sizes within a score. This is achieved with an internal scaling factor. If the scaling factor is forgotten in some places, objects generally become too thick or too large on smaller staves.

staff-mixed-size.ly

[image of music]

Symbols that need on-staffline info (like dots and ties) continue to work in absence of a staff-symbol.

staff-online-symbol-absence.ly

[image of music]

An ossia staff without a Time_signature_engraver stops right at the bar line.

staff-ossia-end-at-time-change.ly

[image of music]

Font size configuration is independent from font family configuration. In this test, the call to set-global-staff-size should not affect the font families defined previously.

staff-size-font-selection.ly

[image of music]

The space between scores containing Staffs and TabStaffs should be consistent. In this example, all of the spacings should be equivalent.

staff-tabstaff-spacing.ly

[image of music]

The staff is a grob (graphical object) which may be adjusted as well, for example, to have 6 thick lines and a slightly large staff-space. However, beams remain correctly quantized.

staff-tweak.ly

[image of music]

Stanza numbers are put left of their lyric. They are aligned in a column.

stanza-number.ly

[image of music]

Cross-staff stems avoid articulations. Articulations that don’t get in the way of stems do not cause unwanted horizontal space.

stem-cross-staff-articulation.ly

[image of music]

The Melody_engraver decides stem direction for notes on the middle staff line based on neighboring notes. Mid-measure repeat bar lines break up the melody as do normal measure bar lines. In this test, marcato marks show the expected stem direction.

stem-direction-context-bar-lines.ly

[image of music]

Context-dependent orientation of the stem for a note on the middle line of the staff can be turned off locally using the suspendMelodyDecisions context property.

In this test, marcato marks show the expected stem direction.

stem-direction-context-pause.ly

[image of music]

Stem directions for notes on the middle staff line are determined by the directions of their neighbors.

stem-direction-context.ly

[image of music]

Stems, beams, ties and slurs should behave similarly, when placed on the middle staff line. Of course stem-direction is down for high notes, and up for low notes.

stem-direction.ly

[image of music]

Stems with overridden ’Y-extent should not confuse height estimation. This example should fit snugly on one page.

stem-length-estimation.ly

[image of music]

Stem length and stem-begin-position can be set manually.

stem-length.ly

[image of music]

Mensural stems must have exact center alignment. This test was made to inspect pixel-granular misalignment bugs.

stem-mensural.ly

[image of music]

Setting Stem.neutral-direction to an invalid direction value does not result in a crash.

stem-neutral-direction-crash.ly

[image of music]

Lilypond gets beamed stem pure heights correct to avoid outside staff collisions.

stem-pure-height-beamed.ly

[image of music]

If note head is ‘over’ the center line, the stem is shortened. This happens with forced stem directions, and with some chord configurations.

stem-shorten.ly

[image of music]

Stemlets don’t cause stems on whole notes.

stem-stemlet-whole.ly

[image of music]

Stemlets are small stems under beams over rests. Their length can be set with stemlet-length.

stem-stemlet.ly

[image of music]

Stem tremolos on cross-staff beams do not cause circular dependencies.

stem-tremolo-cross-staff-beam.ly

[image of music]

Tremolo works even when a stem is forced in a particular direction.

stem-tremolo-forced-dir.ly

[image of music]

Tremolos should avoid other notes in the staff as best as possible and issue a warning otherwise.

stem-tremolo-note-collision.ly

[image of music]

Stem tremolos count in a note column’s horizontal skyline.

stem-tremolo-note-column.ly

[image of music]

Tremolos are positioned a fixed distance from the end of the beam. Tremolo flags are shortened and made rectangular on beamed notes or on stem-up notes with a flag. Tremolo flags are tilted extra on stem-down notes with a flag.

stem-tremolo-position.ly

[image of music]

stem tremolo vertical distance also obeys staff-space settings.

stem-tremolo-staff-space.ly

[image of music]

Controlling the appearance of tremolo slashes. Property slope is self-explanatory. Property shape determines whether slashes look like rectangles or like very small beams. Setting these properties directly cause all slashes behave in the specified way. However, one usually wants the slashes to behave differently depending on whether the note has flags, beams or only a plain stem. That’s what the style property is used for: it sets shape and slope depending on the situation. There are two styles defined: default and constant.

stem-tremolo-style.ly

[image of music]

Stem tremolos or rolls are tremolo signs that look like beam segments crossing stems. If the stem is in a beam, the tremolo must be parallel to the beam. If the stem is invisible (e.g. on a whole note), the tremolo must be centered on the note. If the note has a flag (eg. an unbeamed 8th note), the tremolo should be shortened if the stem is up and tilted extra if the stem is down.

The tremolos should be positioned a fixed distance from the end of the stems unless there is no stem, in which case they should be positioned a fixed distance from the note head.

If an impossible tremolo duration (e.g. :4) is given, a warning is printed.

stem-tremolo.ly

[image of music]

In this test, the vertical distance between two adjacent staves should be large enough to avoid a clash if the stems are very close.

stems-clash-between-staves.ly

[image of music]

Combinations of rotation and color do work.

stencil-color-rotation.ly

[image of music]

Tests all lilypond stencil commands that are relevant to PDF output

stencil-expressions.ly

[image of music]

You can write stencil callbacks in Scheme, thus providing custom glyphs for notation elements. A simple example is adding parentheses to existing stencil callbacks.

The parenthesized beam is less successful due to implementation of the Beam. The note head is also rather naive, since the extent of the parens are also not seen by accidentals.

stencil-hacking.ly

[image of music]

Stencils can be scaled using ly:stencil-scale. Negative values will flip or mirror the stencil without changing its origin; this may result in collisions unless the scaled stencil is realigned (e.g., the time signature in this test).

stencil-scale.ly

[image of music]

Sticky spanners also work when the host’s bounds are not set immediately, such as with a hairpin ending on a skip.

sticky-late-bounds.ly

[image of music]

Sticky grobs can be attached to other sticky grobs.

sticky-second-order.ly

[image of music]

Sticky spanners have their end announced as soon as their host’s is announced.

sticky-spanner-end-announcement.ly

[image of music]

String numbers should only be moved outside slurs when there is a collision.

string-number-around-slur.ly

[image of music]

String numbers don’t segfault when their stencil is set to ##f.

string-number-no-stencil.ly

[image of music]

Different styles may be used for string number indications. Predefined options are arabic (used by default) and roman numerals.

string-number-styles.ly

[image of music]

String numbers can be added to chords. They use the same positioning mechanism as finger instructions.

string-number.ly

[image of music]

Stroke fingerings don’t segfault when their stencil is set to ##f.

stroke-fingering-no-stencil.ly

[image of music]

SVG output attributes are not duplicated.

The proper way to know if this test passes is to compile it into an SVG file (with --svg) and check the generated SVG code.

svg-duplicate-attribute.ly

[image of music]

Tests for swing.ly

swing-test.ly

[image of music]

The size of every system is correctly determined; this includes postscript constructs such as slurs.

system-extents.ly

[image of music]

By setting the padding between systems to a negative value, it is possible to eliminate the anti-collision constraints.

system-overstrike.ly

[image of music]

System separator positioning works with all spaceable staff contexts.

system-separator-spaceable-staves.ly

[image of music]

System separators may be defined as markups in the system-separator-markup field of the paper block. They are centered between the boundary staves of each system.

system-separator.ly

[image of music]

When the staff-space is increased, the system-start delimiter should still be collapsed (i.e. the collapse-height should not give an absolute length, but a multiple of staff-spaces).

system-start-bar-collapse-staffspace.ly

[image of music]

Disregarding the value of systemStartDelimiter, setting SystemStartGrob style of StaffGroup to 'brace always prints a SystemStartBrace.

Every StaffGroup should start with a SystemStartBrace.

system-start-brace-style.ly

[image of music]

A piano context included within a staff group should cause the piano brace to be drawn to the left of the staff angle bracket.

system-start-bracket.ly

[image of music]

A heavy-bar system start delimiter may be created by tuning the SystemStartBar grob.

system-start-heavy-bar.ly

[image of music]

Deeply nested system braces, brackets, etc., may be created with the systemStartDelimiterHierarchy property.

system-start-nesting.ly

[image of music]

Additional bass strings (for baroque lute, etc.) are supported in TabStaff. They are printed below lowest line as: a, /a, //a, ///a, 4, 5 etc. additionalBassStrings needs to be set accordingly.

tablature-additional-bass-strings.ly

[image of music]

Using the whiteout-color property it is possible to adjust TabStaff to a colored background.

tablature-background-color.ly

[image of music]

Tablature may also be tuned for banjo.

tablature-banjo.ly

[image of music]

In a TabStaff, the chord repetition function needs to retain string and fingering information. Using \tabChordRepeats achieves that, in contrast to the music on the main staff.

tablature-chord-repetition-finger.ly

[image of music]

In a TabStaff, the chord repetition function needs to save the string information. The obsolete function \tabChordRepetition establishes this setting score-wide. Nowadays, you would rather use just \tabChordRepeat on the music in the tabstaff, not affecting other contexts.

tablature-chord-repetition.ly

[image of music]

Context property defaultStrings defines desired strings for fret calculations if no strings are defined explicitly.

tablature-default-strings.ly

[image of music]

With full notation, the dots on the tablature heads should respect two-digit fret numbers.

tablature-dot-placement.ly

[image of music]

Tremoli applied to double stems in a TabVoice should be centered on the double stem.

tablature-double-stem-tremolo.ly

[image of music]

Tablatures derived from stored fretboard diagrams display open strings as fret 0 in the tablature. The tablature and fretboard should match.

tablature-fretboard-open-string.ly

[image of music]

As default, tablature staves show only the fret numbers, because in most situations, they are combined with normal staves. When used without standard notation, tabFullNotation can be used.

tablature-full-notation.ly

[image of music]

Glissando lines in tablature have the right slope.

tablature-glissando.ly

[image of music]

Fret numbers belonging to grace notes are smaller.

tablature-grace-notes.ly

[image of music]

Harmonics can be specified either by ratio or by fret number.

tablature-harmonic-functions.ly

[image of music]

When a harmonic note is tied in tablature, neither the fret number nor the harmonic brackets for the second note appear in the tablature.

tablature-harmonic-tie.ly

[image of music]

Harmonics get angled brackets in tablature. Harmonics in chords should retain their proper position, regardless of whether or not strings are specified. In this example, the harmonics should always be on string 1.

tablature-harmonic.ly

[image of music]

A sample tablature with lettered tab, using fretLabels to modify the fret letters.

By default, letters are drawn sequentially from the alphabet, but if the context property fretLabels is defined, these are substituted. If specified, the length of fretLabels must be sufficient to label all the frets used. A warning is issued if the length is too short.

tablature-letter.ly

[image of music]

The TabStaff will print micro-tones as mixed numbers of fret-number and a fraction. The context-property supportNonIntegerFret needs to be set #t in Score-context. FretBoards will print those micro-tones only if they can be found in the chosen settings for stringTunings, otherwise a warning (surpressed here) will be printed and an empty FretBoard returned. Which should be the case for the last four of the examples pitches. Micro-tones assigned to strings work nicely.

tablature-micro-tone.ly

[image of music]

Negative fret numbers calculated due to assigning a string number can be displayed, ignored, or recalculated. Here we should have all three cases demonstrated.

tablature-negative-fret.ly

[image of music]

A spacer at begin of a new line does not error.

tablature-new-line-spacer.ly

[image of music]

Open strings can always be part of a chord in tablature, even when frets above 4 have been used in the chord. In this case, both chords should show an open fourth string.

tablature-open-string-chord.ly

[image of music]

Open strings are part of a chord in tablature, even when minimumFret is set. This can be changed via restrainOpenStrings.

tablature-open-string-handling.ly

[image of music]

If a RepeatTie occurs, the corresponding fret number is always displayed in parentheses.

tablature-repeat-tie.ly

[image of music]

How a repeat sign looks in tablature.

tablature-repeat.ly

[image of music]

Tab supports slides.

tablature-slide.ly

[image of music]

Slur placement in complementary tablatures should not be affected by either automatic or manual beaming.

tablature-slurs-with-beams.ly

[image of music]

For other tunings, it is sufficient to set stringTunings. The number of staff lines is adjusted accordingly.

tablature-string-tunings.ly

[image of music]

In tablature, notes that are tied to are invisible except after a line break or within a second volta; here, the fret number is displayed in parentheses.

As an option, the notes that are tied to may become invisible completely, even after line breaks while applying hideSplitTiedTabNotes. showSplitTiedTabNotes switches back to default behaviour.

tablature-tie-behaviour.ly

[image of music]

If a Slur or a Glissando follows a Tie, the corresponding fret number is displayed in parentheses.

tablature-tie-spanner.ly

[image of music]

Tremolos will appear on tablature staffs only if \tabFullNotation is active. Otherwise, no tremolo indications are displayed on the TabStaff. Also, tablature beams are the same thickness on TabStaff and Staff.

tablature-tremolo.ly

[image of music]

A fingering indication of zero counts as an open string for fret calculations. An inappropriate request for an open string will generate a warning message and set the requested pitch in the tablature.

tablature-zero-finger.ly

[image of music]

A sample tablature, with both normal staff and tab.

Tablature is done by overriding the note-head formatting function, and putting it on a 6-line staff. A special engraver takes care of going from string-number + pitch to number.

String numbers can be entered as note articulations (inside a chord) and chord articulations (outside a chord)

tablature.ly

[image of music]

A TabStaff placed inside a ChoirStaff does not have an extraneous bracket. In this test, the two snippets should look the same.

tabstaff-choirstaff-brace.ly

[image of music]

The \tag command marks music expressions with a name. These tagged expressions can be filtered out later. This mechanism can be used to make different versions of the same music. In this example, the top stave displays the music expression with all tags included. The bottom two staves are filtered: the part has cue notes and fingerings, but the score has not.

tag-filter.ly

[image of music]

The operation of \keepWithTag can be made more flexible by using \tagGroup.

tag-group.ly

[image of music]

The \removeWithTag and \keepWithTag commands can name multiple tags to remove or to keep.

tag-multiple.ly

[image of music]

Compound articulations with \tenuto are stacked correctly, independent of input order.

tenuto-priority.ly

[image of music]

A text mark created by \textEndMark is visible everywhere except at the beginning of a line.

text-end-mark-break-visibility.ly

[image of music]

A text mark created by \textMark is visible everywhere except at the end of a line.

text-mark-break-visibility.ly

[image of music]

\markLengthOn also works on text marks.

text-mark-marklengthon.ly

[image of music]

The \textMark and \textEndMark commands draw arbitrary textual indications between notes.

text-mark.ly

[image of music]

text replacement settings are scoped to the \paper block

text-replacement-scoping.ly

[image of music]

Text replacements can replace strings with arbitrary markups.

text-replacements-replace-with-markup.ly

[image of music]

When \smallCaps and text replacements are used together, the result of text replacements is also written in small caps.

text-replacements-smallcaps.ly

[image of music]

Text replacements can replace patterns containing non-ASCII characters. In particular, this test should also work if compiled under a non-Unicode-aware locale (e.g., LC_ALL=C lilypond …).

text-replacements-unicode.ly

[image of music]

TextScripts are spaced closely, following outlines of the stencil. When markup commands like pad-around and with-dimensions change the extent of a stencil, these changed extents have effect in the stencil outline used to place the resulting TextScript.

text-script-vertical-skylines.ly

[image of music]

Text and trill spanners are attached to note columns, so attachments in other staves have no effect on them.

text-spanner-attachment-alignment.ly

[image of music]

Text spanners ending on, or broken across, full-measure rests extend to the rests, or over the rests, as appropriate.

text-spanner-full-rest.ly

[image of music]

The order of setting nested properties does not influence text spanner layout.

text-spanner-override-order.ly

[image of music]

Text spanners should not repeat start text when broken.

text-spanner.ly

[image of music]

\etc can be used for constructing event functions for ‘TextScript’ events with sequences starting with ‘-’, ‘^’, or ‘_’. This example should have notes all adorned in the same manner.

textetc.ly

[image of music]

lilypond should flip the tie’s direction to avoid a collision with the sharp.

tie-accidental.ly

[image of music]

Advanced tie chord formatting also works with arpegiated ties. Due to arpeggios, tie directions may be changed relative to the unarpegiated case.

tie-arpeggio-collision.ly

[image of music]

when tieWaitForNote is set, the right-tied note does not have to follow the lef-tied note directly. When tieWaitForNote is set to false, any tie will erase all pending ties.

tie-arpeggio.ly

[image of music]

Broken ties honor minimum-length also. This tie has a minimum-length of 5.

tie-broken-minimum-length.ly

[image of music]

Broken tie lengths are not affected by clefs in other staves.

tie-broken-other-staff.ly

[image of music]

Ties behave properly at line breaks.

tie-broken.ly

[image of music]

Tie detail property multi-tie-region-size controls how many variations are tried for the extremal ties in a chord.

tie-chord-broken-extremal.ly

[image of music]

Switching on debug-tie-scoring annotates the tie scoring decisions made.

tie-chord-debug.ly

[image of music]

Individual chord notes can also be tied

tie-chord-partial.ly

[image of music]

In chords, ties keep closer to the note head vertically, but never collide with heads or stems. Seconds are formatted up/down; the rest of the ties are positioned according to their vertical position.

The code does not handle all cases. Sometimes ties will printed on top of or very close to each other. This happens in the last chords of each system.

tie-chord.ly

[image of music]

The appearance of ties may be changed from solid to dotted or dashed.

tie-dash.ly

[image of music]

In the single tie case, broken ties peek across line boundaries to determine which direction to take.

tie-direction-broken.ly

[image of music]

Tie directions can be set with _ and ^. This makes correction in complex chords easier.

tie-direction-manual.ly

[image of music]

Ties avoid collisions with dots.

tie-dot.ly

[image of music]

LilyPond should accept a tie between notes which are enharmonically identical.

tie-enharmonic.ly

[image of music]

Tying a grace to a following grace or main note works.

tie-grace.ly

[image of music]

If using exact values (this is, either integers or rational values like ‘(/ 4 5)’), staff-position is used to vertically tune the tie for staff line avoidance. If using an inexact value like a floating point number, it is taken as the vertical location.

tie-manual-vertical-tune.ly

[image of music]

Tie formatting may be adjusted manually, by setting the tie-configuration property. The override should be placed at the second note of the chord.

You can leave a Tie alone by introducing a non-pair value (eg. #t) in the tie-configuration list.

tie-manual.ly

[image of music]

The pitch of a pitched trill should not trigger a warning for unterminated ties.

tie-pitched-trill.ly

[image of music]

Like normal ties, single semities (LaissezVibrerTie or RepeatTie) get their direction from the stem direction, and may be tweaked with 'direction.

tie-semi-single.ly

[image of music]

Tie directions are also scored. In hairy configurations, the default rule for tie directions is overruled.

tie-single-chord.ly

[image of music]

Individual ties may be formatted manually by specifying their direction and/or staff-position.

tie-single-manual.ly

[image of music]

Formatting for isolated ties.

  • short ties are in spaces
  • long ties cross staff lines
  • ties avoid flags of left stems.
  • ties avoid dots of left notes.
  • short ties are vertically centered in the space, as well those that otherwise don’t fit in a space
  • extremely short ties are put over the noteheads, instead of between.

tie-single.ly

[image of music]

When a tie is followed only by unmatching notes and the tie cannot be created, lilypond prints out a warning unless tieWaitForNote is set.

tie-unterminated.ly

[image of music]

For whole notes, the inside ties do not cross the center of the note head, horizontally.

tie-whole.ly

[image of music]

\time with a zero denominator results in a warning.

time-denominator-zero.ly

[image of music]

\time with a zero numerator results in a warning.

time-numerator-zero.ly

[image of music]

This test covers the mensural and neomensural time signature styles.

time-signature-mensural.ly

[image of music]

Mid-measure time signature changes not accompanied by \partial generate warnings.

time-signature-midmeasure-warning.ly

[image of music]

Mid-measure time signature changes must be accompanied by \partial.

In this example, no bar numbers should be omitted or repeated, and all double bar lines should have parenthesized bar numbers consistent with the single bar lines. Both scores should look identical.

  • \time 2/4 occurs at a negative position
  • \time 6/8 occurs at a position less than the new measure length
  • \time 3/8 occurs at a position equal to the new measure length
  • \time 3/16 occurs at a position greater than the new measure length

time-signature-midmeasure.ly

[image of music]

The numbered time signature style prints a fraction.

time-signature-numbered.ly

[image of music]

\numericTimeSignature and \defaultTimeSignature, like \time, affect all simultaneous staves.

time-signature-numeric-and-default.ly

[image of music]

Setting Timing.timeSignatureFraction to #f prints a special sign in place of a time signature, provided that TimeSignature is appropriately configured. The first and third measures should have an X-shaped sign.

time-signature-senza-misura-context.ly

[image of music]

When the Timing context is initialized with timeSignatureFraction = ##f, various derived properties are set accordingly. The output should have no time signature or bar lines.

time-signature-senza-misura-initial.ly

[image of music]

\senzaMisuraTimeSignatureX and \senzaMisuraTimeSignatureOff control the creation of an X sign when TimeSignature.fraction is not set. The middle bar of the middle staff should contain an X-shaped sign and a quarter note.

time-signature-senza-misura-stencil.ly

[image of music]

Default values for time signature settings can vary by staff if the Timing_translator is moved from Score to Staff. In this case, the upper staff should be beamed 3/4, 1/4. The lower staff should be beamed 1/4, 3/4.

time-signature-settings-by-staff.ly

[image of music]

\overrideTimeSignatureSettings can set beaming properties to use when timeSignatureFraction is #f. The output should have no time signature or bar lines. The first 15 notes should be grouped 1,2,3,4,5.

time-signature-settings-senza-misura.ly

[image of music]

The single-number time signature style prints the numerator only.

time-signature-single-number.ly

[image of music]

Demonstrate all titling variables used by default.

titling.ly

[image of music]

The input representation is generic, and may be translated to XML.

to-xml.ly

[image of music]

There is no error when a file contains TOC items but no TOC.

toc-items-no-toc.ly

[image of music]

A missing node in a structured TOC is handled gracefully.

toc-missing-node.ly

[image of music]

ToC items on the same page stay in the same order as PDF bookmarks. (The order of ToC items and PDF bookmarks may differ in other documents.)

toc-multiple-entries-on-same-page.ly

[image of music]

In structured tables of contents, the first path component of an entry can refer to a previously defined node anywhere in the tree. The rest of the path is directly interpreted from this initial node.

toc-structured-naming-conflicts.ly

[image of music]

TOC labels can be explicitly specified, and structured hierarchically; they appear in PDF bookmarks as well (the ‘table of contents’ panel in PDF viewers). PDF bookmarks are reordered so as to not ‘go back in time’.

toc-structured.ly

[image of music]

A table of contents is included using \markuplist \table-of-contents. The toc items are added with the \tocItem command. In the PDF backend, the toc items are linked to the corresponding pages.

toc.ly

[image of music]

Trill spanners stop before the accidental of the following note, if any.

trill-spanner-accidental.ly

[image of music]

Consecutive trill spans work without explicit \stopTrillSpan commands, since successive trill spanners will automatically become the right bound of the previous trill.

trill-spanner-auto-stop.ly

[image of music]

A TrillSpanner crossing a line break should restart exactly above the first note on the new line.

trill-spanner-broken.ly

[image of music]

Chained trills end at the next trill or bar line. Collisions can be prevented by overriding bound-details.

trill-spanner-chained.ly

[image of music]

Consecutive trill spanners never overlap.

trill-spanner-consecutive.ly

[image of music]

The direction of a trill spanner can be set with _ and ^ indicators.

trill-spanner-direction.ly

[image of music]

Trill spanner can end on a grace note

trill-spanner-grace.ly

[image of music]

Trill spanners with outside-staff-priority turned off do not collide with notes.

trill-spanner-no-outside-staff-priority.ly

[image of music]

Pitched trills on consecutive notes with the same name and octave should not lose accidentals; in the following example, accidentals should be visible for all trill-pitches.

trill-spanner-pitched-consecutive.ly

[image of music]

Pitched trill accidentals can be forced.

trill-spanner-pitched-forced.ly

[image of music]

Pitched trills are denoted by a small note head in parentheses following the main note. This note head is properly ledgered, and parentheses include the accidental.

trill-spanner-pitched.ly

[image of music]

The horizontal position of the beginning of a trill spanner is positioned correctly relative to the note head it is attached to, even if scaled to a smaller size.

trill-spanner-scaled.ly

[image of music]

A trill spanner can be made to run to the end of the score by never issuing a \stopTrillSpan command.

trill-spanner-terminated-implicitly.ly

[image of music]

By default, a trill spanner ending on the first note on a bar extends no further than the preceding bar line.

trill-spanner-to-barline.ly

[image of music]

The trill symbol and the wavy line are neatly aligned: the wavy line should appear to come from the crook of the r

trill-spanner.ly

[image of music]

Paths can be empty, or contain just a moveto command. The extents of such a path are empty.

trivial-path.ly

[image of music]

In combination with a beam, the bracket of the tuplet bracket is removed. This only happens if there is one beam, as long as the bracket.

tuplet-beam.ly

[image of music]

Tuplet brackets should align to visible or transparent stems only. For stemless notes or rests they should span the whole note width.

tuplet-bracket-X-positions.ly

[image of music]

TupletBracket grobs avoid Fingering grobs.

tuplet-bracket-avoid-fingering.ly

[image of music]

Tuplet brackets avoid scripts by default.

tuplet-bracket-avoid-scripts.ly

[image of music]

TupletBracket grobs avoid StringNumber grobs.

tuplet-bracket-avoid-string-number.ly

[image of music]

When the tuplet number is wider than the bracket, no tuplet bracket is printed.

tuplet-bracket-backwards.ly

[image of music]

Cross-staff tuplets are drawn correctly, even across multiple staves.

tuplet-bracket-cross-staff.ly

[image of music]

The direction of tuplet brackets is the direction of the majority of the stems under the bracket, with ties going to UP.

tuplet-bracket-direction.ly

[image of music]

Tuplet brackets are not too steep. In groups without beams, their angle should match an equivalent beam slant when possible.

tuplet-bracket-max-slope.ly

[image of music]

Tuplet brackets’ outside staff priority can be set. Brackets, by default, carry their numbers with them.

tuplet-bracket-outside-staff-priority.ly

[image of music]

Tuplet brackets can be set to always be printed when the direction of the bracket is forced to be on the note head side. This setting doesn’t have any effect on kneed tuplets.

tuplet-bracket-over-note-heads.ly

[image of music]

The option span-all-note-heads may be used to make tuplet brackets span over all note heads (instead of stems) as done in standard typesetting practice.

tuplet-bracket-span-all-note-heads.ly

[image of music]

Tuplet brackets do not push objects with outside-staff-priority too high.

tuplet-bracket-vertical-skylines.ly

[image of music]

The default behavior of tuplet-bracket visibility is to print a bracket unless there is a beam of the same length as the tuplet. Overriding 'bracket-visibility changes the bracket visibility as follows:

  • #t (always print a bracket)
  • #f (never print a bracket)
  • 'if-no-beam (only print a bracket if there is no beam)

tuplet-bracket-visibility.ly

[image of music]

Broken tuplets are adorned with little arrows. The arrows come from the edge-text property, and thus be replaced with larger glyphs or other text.

tuplet-broken.ly

[image of music]

With full-length-to-extent, the extent of the attaching column for a full-length tuplet bracket can be ignored.

tuplet-full-length-extent.ly

[image of music]

tuplet can be made to run to prefatory matter or the next note, by setting tupletFullLengthNote.

tuplet-full-length-note.ly

[image of music]

If tupletFullLength is set, tuplets end at the start of the next non-tuplet note.

tuplet-full-length.ly

[image of music]

The size of the tuplet bracket gap is adjusted to the width of the text.

tuplet-gap.ly

[image of music]

Overlong tuplet span specifications are reduced to the actual length.

tuplet-long-spanner.ly

[image of music]

A misplaced tuplet (starting while a note is playing) is handled robustly.

tuplet-misplaced.ly

[image of music]

Nested tuplets do collision resolution, also when they span beams.

tuplet-nest-beam.ly

[image of music]

Broken nested tuplets avoid each other correctly.

tuplet-nest-broken.ly

[image of music]

Tuplets may be nested.

tuplet-nest.ly

[image of music]

Removing Stem_engraver doesn’t cause crashes.

tuplet-no-stems.ly

[image of music]

Tuplet numbers of flat beams vertically align with similar looking beams.

tuplet-number-alignment.ly

[image of music]

Tuplet numbers are positioned correctly on kneed French-style beams.

tuplet-number-french-kneed-beams.ly

[image of music]

In tuplets with an even number of stems, the number may be placed on either side of the beam when the central stems point in different directions. The exception to this is when there is a fractional beam on one of the central stems, in which case the number is placed opposite the partial beam.

tuplet-number-kneed-beam-even-stem-count.ly

[image of music]

Tuplet numbers are placed next to the beam unless there is insufficient horizontal space for them, in which case bracket-based positioning is used and a programming error is issued.

The first tuplet number should be between stems; the second should be below the noteheads.

tuplet-number-kneed-beam-horizontal-fit.ly

[image of music]

A tuplet number associated with a kneed beam is not placed between beam and staff where it may collide with ledger lines.

tuplet-number-kneed-beam-ledger-lines.ly

[image of music]

Tuplet numbers are placed next to kneed beams when Beam.positions is overridden.

tuplet-number-kneed-beam-positions.ly

[image of music]

Grobs whose parents have outside-staff-priority set should figure into the vertical skyline of the VerticalAxisGroup such that grobs with a higher outside-staff-priority are correctly positioned above them.

tuplet-number-outside-staff-positioning.ly

[image of music]

Tuplet numbers’ outside staff priority can be set.

tuplet-number-outside-staff-priority.ly

[image of music]

Tuplet numbers will maintain a constant distance from kneed beams when offset horizontally.

tuplet-number-shift-along-kneed-beam.ly

[image of music]

Tuplet number position is correct when slurs and scripts are present.

tuplet-number-slur-script.ly

[image of music]

Tuplet numbers that are slightly outside the staff sit on the staff line.

tuplet-number-staffline-size10.ly

[image of music]

Tuplet numbers that are slightly outside the staff sit on the staff line.

tuplet-number-staffline-size40.ly

[image of music]

Tuplet numbers that are slightly outside the staff sit on the staff line.

tuplet-number-staffline.ly

[image of music]

Tuplet numbers associated with kneed beams will avoid accidentals.

tuplet-numbers-kneed-beams-accidentals.ly

[image of music]

Tuplet numbers are positioned next to kneed beams.

tuplet-numbers-kneed-beams.ly

[image of music]

Tuplet bracket formatting supports numerous options, for instance, bracketed (B) and non-bracketed (NB).

tuplet-properties.ly

[image of music]

Tuplets may contain rests.

tuplet-rest.ly

[image of music]

Regression test for Issue #6205. Expected output is a single staff with notes C and E.

tuplet-set.ly

[image of music]

Show tuplet numbers also on single-note tuplets (otherwise the timing would look messed up!), but don’t show a bracket. Make sure that tuplets without any notes don’t show any number, either.

tuplet-single-note.ly

[image of music]

A tuplet with only skips is silently omitted.

tuplet-skips.ly

[image of music]

Tuplet brackets stay clear of the staff. The slope is determined by the graphical characteristic of the notes, but if the musical pattern does not follow graphical slope, then the bracket is horizontal

The bracket direction is determined by the dominating stem direction.

tuplet-slope.ly

[image of music]

Tuplet slurs may be tweaked through the shorten-pair and dash-definition properties.

tuplet-slur-tweaks.ly

[image of music]

Slurs may be used instead of brackets for tuplets through the tuplet-slur property of TupletBracket. Rules for visibility are the same as for regular brackets, so bracket-visibility should be set to #t if the slur is desired for beamed groups.

tuplet-slurs.ly

[image of music]

Horizontal tuplet brackets are shifted vertically to avoid staff line collisions.

tuplet-staffline-collision.ly

[image of music]

Subdivision works properly for tuplets.

tuplet-subdivision.ly

[image of music]

Non-standard tuplet texts: Printing other tuplet fractions than the ones actually assigned.

tuplet-text-different-numbers.ly

[image of music]

Non-standard tuplet texts: Printing a tuplet fraction with note durations assigned to both the denominator and the numerator.

tuplet-text-fraction-with-notes.ly

[image of music]

Non-standard tuplet texts: Appending a note value to the normal text and to the fraction text.

tuplet-text-note-appended.ly

[image of music]

Tuplets are indicated by a bracket with a number. There should be no bracket if there is a beam exactly matching the length of the tuplet. The bracket does not interfere with the stafflines, and the number is centered in the gap in the bracket.

The bracket stops at the end of the stems, if the stems have the same direction as the bracket. The endings can be adjusted with bracket-flare.

tuplets.ly

[image of music]

Alternative notation systems using accidentals different from the Western ones set them systematically, for standalone markups and all grobs that print accidentals.

This include file provides a function to draw many accidental in different contexts. It is used by various tests.

turkish-makam-accidental-glyphs.ly

[image of music]

Overrides can be the target of a \propertyTweak, with the tweaks accumulating as override. The main application is for stacking commands implemented in terms of \propertyTweak. This example should show the starting chord with blue, cross-styled note heads and a red stem.

tweaks-as-overrides.ly

[image of music]

heavily mutilated Edition Peters Morgenlied by Schubert

typography-demo.ly

[image of music]

\unfolded hides music until a repeat is unfolded. In this case, a second staff appears when the piece is unfolded.

unfolded-spec.ly

[image of music]

unpure-pure containers take two arguments: an unpure property and a pure property. The pure property is evaluated (and cached) for all pure calculations, and the unpure is evaluated for all unpure calculations. In this regtest, there are three groups of two eighth notes. In the first group, the second note should move to accommodate the flag, whereas it should not in the second group and in the third group because it registers the flag as being higher. The flag, however, remains at the Y-offset dictated by ly:flag::calc-y-offset. In the fourth set of two 8th notes, the flag should be pushed up to a Y-offset of 8.

unpure-pure-container.ly

[image of music]

\once \unset should change a context property value for just one timestep and then return to the previous value.

unset-once.ly

[image of music]

words in mixed font in a single string are separated by spaces as in the input string. Here a Russian word followed by a roman word.

utf-8-mixed-text.ly

[image of music]

In Guile v2, embedded Scheme can contain UTF-8 strings and identifiers. Here, identifer bääh contains music with the text "bööh"

utf-8-scheme.ly

[image of music]

Various scripts may be used for texts (like titles and lyrics) by entering them in UTF-8 encoding, and using a Pango based backend. Depending on the fonts installed, this fragment will render Bulgarian (Cyrillic), Hebrew, Japanese and Portuguese.

utf-8.ly

[image of music]

The Scheme function ly:version? checks that the version of LilyPond being used satisfies a comparison predicate against a given version.

version-compare.ly

[image of music]

This does not produce typeset output but checks that \version statements in included files do not inhibit the warning in the main file when a \version statement is missing there.

version-seen.ly

[image of music]

Score level Vertical_align_engraver ignore axis groups that are not spanners. In this case, the Devnull context has no Axis_group_engraver, so the NoteColumn appears like a parent-less axis group; even so, the Score level alignment ignores it.

vertical-alignment-spanner-only.ly

[image of music]

Voice followers can be broken across more than two systems.

voice-follower-broken-several-systems.ly

[image of music]

Voice followers have acceptable slopes across lines breaks.

voice-follower-broken.ly

[image of music]

Adjustments to VoiceFollower.bound-details.left.Y are relative to the VoiceFollower grob’s start staff. In this test, the lines should start and end at the exact middle of the respective staves.

voice-follower-y-tweaks.ly

[image of music]

Whenever a voice switches to another staff a line connecting the notes can be printed automatically. This is enabled if the property followVoice is set to true.

voice-follower.ly

[image of music]

The \voices command can be used for continuing voices and changing the order of \voiceOne\voiceFour style overrides.

voices-command.ly

[image of music]

Volta bracket end hooks can be added for other bar line types.

volta-bracket-add-volta-hook.ly

[image of music]

When alternatives are nested, volta brackets stack with the outermost alternative on top. In this case, alternatives for volte 2-5 and 6 are nested inside an alternative for volte 2-6.

volta-bracket-nest.ly

[image of music]

Volta brackets are vertically fit to objects below them.

volta-bracket-vertical-skylines.ly

[image of music]

Broken volta spanners behave correctly at their left edge in all cases.

volta-broken-left-edge.ly

[image of music]

Volte using repeatCommands can have markup text.

volta-markup-text.ly

[image of music]

By putting Volta_engraver in a staff context, one can get volta brackets on staves other than the topmost one.

volta-multi-staff-inner-staff.ly

[image of music]

By default, the volta brackets appear only in the topmost staff.

volta-multi-staff.ly

[image of music]

The offset of the volta number can be controlled with the property volta-number-offset.

volta-number-offset.ly

[image of music]

A final volta bracket overhanging the next section can be achieved manually with the repeatCommands property and the deprecated voltaSpannerDuration property.

volta-overhang-manual.ly

[image of music]

A final volta bracket overhanging the next section can be achieved by overriding Score.VoltaBracket.musical-length in a zero-duration alternative. The bracket for volta 2 should end 1/3 of the way into the final measure.

volta-overhang.ly

[image of music]

\volta can add volta-specific grace notes.

volta-spec-after-grace.ly

[image of music]

\volta can add a volta-specific dynamic.

volta-spec-dynamic.ly

[image of music]

Simultaneous alternatives can appear as elements of sequential alternatives. The simultaneous alternatives are used in order as the sequential alternative is unfolded.

volta-spec-in-alternative.ly

[image of music]

\volta is useful for nth-time-only music. Desired explanatory text must be added manually.

volta-spec-once.ly

[image of music]

A new context inside \volta ends at the proper time. The staff with an A note should have only one measure.

volta-spec-ossia.ly

[image of music]

\volta is useful for volta-specific rhythms.

volta-spec-rhythm.ly

[image of music]

Regression test for Issue #6207. Expected output is a single staff with notes C and E.

volta-spec-set.ly

[image of music]

\volta can add a volta-specific tie.

volta-spec-tie.ly

[image of music]

Simultaneous alternatives in nested repeats are unfolded according to the innermost repeat. In this test, the upper voice has two groups of three and the lower voice has three groups of two.

volta-spec-unfold-in-unfold.ly

[image of music]

When unfolding volta-specific music, music marked for an out-of-range volta is ignored. In this case, four notes marked 1-4 should appear.

volta-spec-unused.ly

[image of music]

\volta and \unfolded can remove/add music in the main body of a repeated section even if they change the length. In this case, a repeat is skipped after D.C.

volta-spec-volta-in-segno.ly

[image of music]

\volta pertains to the innermost repeat. In this case, alternative notes are inside a volta repeat, so they are engraved as chords even though the volta repeat is inside an unfolded repeat.

volta-spec-volta-in-unfold.ly

[image of music]

\volta can remove arbitrary music from the main body of a repeated section. In each staff, a rest between those marked 1 and 2 has been removed.

volta-unused.ly

[image of music]

A vowel transition runs to the end of the line if it continues on the next line, or if the next lyric syllable is at the first note on the next line. Transition arrows are printed at the beginning of the line only when they go past the first note, or when property after-line-breaking is #t.

vowel-transition-broken.ly

[image of music]

The length of the transition between one syllable and the next is indicated by the length of the arrow, which may not start immediately after a new syllable.

vowel-transition-delayed-start.ly

[image of music]

For vowel transitions, minimum-length refers to the drawn length of the arrow. The protrusion of the syllables and padding is in effect added to minimum-length for spacing. This default behavior can be changed by overriding springs-and-rods, which may cause the transition arrow not to be drawn if there is insufficient space (rather than adding the space necessary to draw it at minimum-length). minimum-length-after-break controls the minimum length of the segment following a system break.

vowel-transition-minimum-length.ly

[image of music]

When a syllable is horizontally offset, the arrow should adjust accordingly.

vowel-transition-offset-syllable.ly

[image of music]

For vowel transitions, left/right padding are independent of left-broken/right-broken padding.

vowel-transition-padding-broken.ly

[image of music]

Padding does not cause VowelTransitions to become shorter than minimum-length. Instead, space is added if necessary leaving the arrow at minimum-length.

vowel-transition-padding.ly

[image of music]

Vowel transition arrows are always drawn, but they do not protrude into the margin. Instead, space is added so that the arrow can be drawn at minimum-length.

vowel-transition-right-margin.ly

[image of music]

A vowel transition arrow may span several notes. The arrow may extend past a rest, but not past the next lyric syllable.

vowel-transition.ly

[image of music]

\vshape works on cross-staff slurs.

vshape-cross-staff.ly

[image of music]

The \vshape command acts like the \shape command, and additionally displays control points and polygons for easier tweaking of the values.

The polygons are drawn on top of other notation, and the points on top of the polygons.

vshape.ly

[image of music]

If you specify two different key signatures at one point, a warning is printed.

warn-conflicting-key-signatures.ly

[image of music]

If a warning is expected, but not triggered, print out a warning about this fact. This will be used to detect missing warnings in our regtests.

warn-expected-warning-missing.ly

[image of music]

A warning is printed if a dynamic spanner is unterminated.

warn-unterminated-span-dynamic.ly

[image of music]

If the ’whiteout property of a grob is set to a number or #t, that part of all objects in lower layers which falls under the extent of the grob’s whiteout area is whited out. Here the TimeSignature whites out the Tie but not the StaffSymbol.

whiteout-lower-layers.ly

[image of music]

The \whiteout command underlays a white background under a markup. The shape is determined by whiteout-style; the default is box, which produces a rectangle. rounded-box produces a rounded rectangle, outline approximates the outline of the markup.

whiteout.ly

[image of music]

Whole note tremolos (and longer) don’t collide with accidentals.

whole-note-tremolo-accidentals.ly

[image of music]

Whole note tremolos that begin on the third line of the staff should have a direction similar to their beamed counterparts.

whole-note-tremolo-direction.ly

[image of music]

This doesn’t produce a warning regarding weird stem size.

whole_note_weird_stem.ly

[image of music]

Empty woodwind diagrams for all instruments in woodwind-diagrams.scm.

woodwind-diagrams-empty.ly

[image of music]

Woodwind diagram with partial fill and trills.

woodwind-diagrams-fill-and-trill.ly

[image of music]

Lists all possible keys for all instruments in woodwind-diagrams.scm

woodwind-diagrams-key-lists.ly

[image of music]

Woodwind diagrams for all instruments in woodwind-diagrams.scm with key names, one pressed per text stencil.

woodwind-diagrams-key-names.ly

[image of music]

Woodwind diagram with ring key and ring trill.

woodwind-diagrams-ring-keys.ly

[image of music]

Woodwind diagrams with text.

woodwind-diagrams-text.ly

[image of music]

Setting staff-space to 0 does not cause a segmentation fault.

zero-staff-space.ly

[image of music]

LilyPond Regression Tests v2.25.23 (development-branch).