@lilypond[quote,ragged-right,verbatim]
{
- \relative c'' { \autoBeamOff
- r8 b c fis, fis c' b e, }
- \addlyrics { Che_in ques -- ta_è_in quel -- l'al -- tr'on -- da }
- \addlyrics { "Che in" ques -- "ta è in" quel -- l'al -- tr'on -- da }
- \addlyrics { Che~in ques -- ta~è~in quel -- l'al -- tr'on -- da }
+ \time 3/4
+ \relative c' { c2 e4 g2 e4 }
+ \addlyrics { gran -- de_a -- mi -- go }
+ \addlyrics { pu -- "ro y ho" -- nes -- to }
+ \addlyrics { pu -- ro~y~ho -- nes -- to }
}
@end lilypond
@lilypond[quote,ragged-right,verbatim]
{
- \relative c'' { \autoBeamOff
- r8 b c fis, fis c' b e, }
- \addlyrics { Che_in ques -- ta_è_in quel -- l'al -- tr'on -- da }
- \addlyrics { "Che in" ques -- "ta è in" quel -- l'al -- tr'on -- da }
- \addlyrics { Che~in ques -- ta~è~in quel -- l'al -- tr'on -- da }
+ \time 3/4
+ \relative c' { c2 e4 g2 e4 }
+ \addlyrics { gran -- de_a -- mi -- go }
+ \addlyrics { pu -- "ro y ho" -- nes -- to }
+ \addlyrics { pu -- ro~y~ho -- nes -- to }
}
@end lilypond
@lilypond[quote,ragged-right,verbatim]
{
- \relative c'' { \autoBeamOff
- r8 b c fis, fis c' b e, }
- \addlyrics { Che_in ques -- ta_è_in quel -- l'al -- tr'on -- da }
- \addlyrics { "Che in" ques -- "ta è in" quel -- l'al -- tr'on -- da }
- \addlyrics { Che~in ques -- ta~è~in quel -- l'al -- tr'on -- da }
+ \time 3/4
+ \relative c' { c2 e4 g2 e4 }
+ \addlyrics { gran -- de_a -- mi -- go }
+ \addlyrics { pu -- "ro y ho" -- nes -- to }
+ \addlyrics { pu -- ro~y~ho -- nes -- to }
}
@end lilypond
@lilypond[quote,ragged-right,verbatim]
{
- \relative c'' { \autoBeamOff
- r8 b c fis, fis c' b e, }
- \addlyrics { Che_in ques -- ta_è_in quel -- l'al -- tr'on -- da }
- \addlyrics { "Che in" ques -- "ta è in" quel -- l'al -- tr'on -- da }
- \addlyrics { Che~in ques -- ta~è~in quel -- l'al -- tr'on -- da }
+ \time 3/4
+ \relative c' { c2 e4 g2 e4 }
+ \addlyrics { gran -- de_a -- mi -- go }
+ \addlyrics { pu -- "ro y ho" -- nes -- to }
+ \addlyrics { pu -- ro~y~ho -- nes -- to }
}
@end lilypond
fet_begingroup ("ties");
-save min_width, max_width, min_height, max_height, thin, thick;
+fet_beginchar ("lyric tie", "lyric");
+ save padding;
-min_width:= .5 staff_space#;
-max_width:= 5 staff_space#;
-min_height := .2 staff_space#;
-max_height := .4 staff_space#;
-thin := 1.2 linethickness;
-thick := 2 linethickness;
-
-def draw_lyric_tie (expr width_sharp) =
- save padding, angularity, width, height, depth;
-
- padding# := .4 staff_space#;
- angularity := 2.5;
- width# := max (min (width_sharp, max_width), min_width);
- height# := (max (width# - min_width, 0) / (max_width - min_width))
- [min_height, max_height];
- depth# := padding# + height#;
+ padding := .4 staff_space;
set_char_box (0, 0,
- depth#, 0);
+ .7 staff_space#, 0);
- define_pixels (width, padding);
-
- z1 = (-width / 2, -padding);
+ z1 = (-staff_space, -padding);
z2 = (0, -d);
- z3 = (width / 2, -padding);
+ z3 = (staff_space, -padding);
- penpos1 (thin, angularity * angle (z2 - z1) + 90);
- penpos2 (thick, 90);
- penpos3 (thin, angularity * angle (z3 - z2) + 90);
+ penpos1 (1.2 linethickness, 50);
+ penpos2 (2 linethickness, 90);
+ penpos3 (1.2 linethickness, 130);
fill z2l
.. simple_serif (z3l, z3r, 90)
.. cycle;
penlabels (1, 2, 3);
-enddef;
-
-fet_beginchar ("short lyric tie", "lyric.short");
- draw_lyric_tie (1.25 staff_space#);
-fet_endchar;
-
-fet_beginchar ("medium lyric tie", "lyric.medium");
- draw_lyric_tie (2 staff_space#);
-fet_endchar;
-
-fet_beginchar ("long lyric tie", "lyric.long");
- draw_lyric_tie (3 staff_space#);
fet_endchar;
fet_endgroup ("ties");
Like simple-markup, but use tie characters for @q{~} tilde symbols.
@lilypond[verbatim,quote]
-\\markup \\column {
- \\tied-lyric #\"Siam navi~all'onde~algenti Lasciate~in abbandono\"
- \\tied-lyric #\"Impetuosi venti I nostri~affetti sono\"
- \\tied-lyric #\"Ogni diletto~è scoglio Tutta la vita~è~un mar.\"
-}
-@end lilypond"
- (define (replace-ties tie str)
- (if (string-contains str "~")
- (let*
- ((half-space (/ word-space 2))
- (parts (string-split str #\~))
- (tie-str (markup #:hspace half-space
- #:musicglyph tie
- #:hspace half-space))
- (joined (list-join parts tie-str)))
- (make-concat-markup joined))
- str))
-
- (define short-tie-regexp (make-regexp "~[^.]~"))
- (define long-tie-regexp (make-regexp "\\w{3,}+~+\\w{3,}"))
- (define (match-short str) (regexp-exec short-tie-regexp str))
- (define (match-long str) (regexp-exec long-tie-regexp str))
-
- (define (replace-short str mkp)
- (let ((match (match-short str)))
- (if (not match)
- (make-concat-markup (list
- mkp
- (replace-ties "ties.lyric.medium" str)))
- (let ((new-str (match:suffix match))
- (new-mkp (make-concat-markup (list
- mkp
- (replace-ties "ties.lyric.medium"
- (match:prefix match))
- (replace-ties "ties.lyric.short"
- (match:substring match))))))
- (replace-short new-str new-mkp)))))
-
- (define (replace-long str mkp)
- (let ((match (match-long str)))
- (if (not match)
- (replace-short str mkp)
- (let ((new-str (match:suffix match))
- (new-mkp (make-concat-markup (list
- (replace-short (match:prefix match)
- mkp)
- (replace-ties "ties.lyric.long"
- (match:substring match))))))
- (replace-long new-str new-mkp)))))
+\\markup {
+ \\tied-lyric #\"Lasciate~i monti\"
+}
+@end lilypond"
+ (if (string-contains str "~")
+ (let*
+ ((half-space (/ word-space 2))
+ (parts (string-split str #\~))
+ (tie-str (markup #:hspace half-space
+ #:musicglyph "ties.lyric"
+ #:hspace half-space))
+ (joined (list-join parts tie-str))
+ (join-stencil (interpret-markup layout props tie-str))
+ )
- (interpret-markup layout
- props
- (replace-long str (markup))))
+ (interpret-markup layout
+ props
+ (make-concat-markup joined)))
+ (interpret-markup layout props str)))
(define-public empty-markup
(make-simple-markup ""))