class Instrument_name_engraver : public Engraver
{
- Item *text_;
- Grob *delim_ ;
- void create_text ();
public:
TRANSLATOR_DECLARATIONS(Instrument_name_engraver);
+protected:
+ Grob *text_;
+
+ virtual void create_text ();
virtual void initialize ();
virtual void acknowledge_grob (Grob_info);
virtual void stop_translation_timestep ();
Instrument_name_engraver::Instrument_name_engraver ()
{
text_ = 0;
- delim_ =0;
}
}
}
+
void
Instrument_name_engraver::create_text ()
{
- if (!text_)
- {
- SCM txt = get_property ("instrument");
+ if (text_)
+ return ;
- if (now_mom () > Moment (0))
- txt = get_property ("instr");
- /*
- UGH.
- */
- if (txt == SCM_EOL)
- return ;
-
- text_ = make_item ("InstrumentName");
-
- if (text_->get_grob_property ("text") != txt)
- text_->set_grob_property ("text", txt);
+ SCM txt = get_property ("instrument");
+
+ if (now_mom () > Moment (0))
+ txt = get_property ("instr");
+ /*
+ UGH.
+ */
+ if (txt == SCM_EOL)
+ return ;
- if (delim_)
- text_->set_parent (delim_, Y_AXIS);
+
+ text_ = make_item ("InstrumentName");
- announce_grob (text_, SCM_EOL);
- }
+ if (text_->get_grob_property ("text") != txt)
+ text_->set_grob_property ("text", txt);
}
void
/* acks */ "bar-line-interface axis-group-interface",
/* reads */ "instrument instr",
/* write */ "");
+
+/****************************************************************/
+
+
+class Vocal_name_engraver : public Instrument_name_engraver
+{
+public:
+ TRANSLATOR_DECLARATIONS(Vocal_name_engraver);
+ virtual void create_text ();
+};
+
+
+Vocal_name_engraver::Vocal_name_engraver ()
+{
+}
+
+
+void
+Vocal_name_engraver::create_text ()
+{
+ if (text_)
+ return ;
+
+ SCM txt = get_property ("vocalName");
+
+ if (now_mom () > Moment (0))
+ txt = get_property ("vocNam");
+
+ /*
+ UGH.
+ */
+ if (txt == SCM_EOL)
+ return ;
+
+ text_ = make_item ("VocalName");
+
+ if (text_->get_grob_property ("text") != txt)
+ text_->set_grob_property ("text", txt);
+}
+
+
+
+ENTER_DESCRIPTION(Vocal_name_engraver,
+/* descr */ " Prints the name of the a lyric voice (specified by "
+" @code{Staff.vocalName} and @code{Staff.vocNam}) "
+"at the left of the staff. ",
+/* creats*/ "VocalName",
+/* accepts */ "",
+/* acks */ "bar-line-interface axis-group-interface",
+/* reads */ "vocNam vocalName",
+/* write */ "");
(font-family . roman)
(meta . ((interfaces . (font-interface self-alignment-interface side-position-interface text-interface break-aligned-interface item-interface ))))
))
+
+ (InstrumentName
+ . (
+ (breakable . #t)
+ (Y-offset-callbacks . (,Side_position_interface::aligned_on_support_refpoints))
+ (direction . 0)
+ (space-alist . ((left-edge . (extra-space . 1.0))
+ ))
+ (molecule-callback . ,Text_item::brew_molecule)
+ (break-align-symbol . instrument-name)
+ (break-visibility . ,begin-of-line-visible)
+ (baseline-skip . 2)
+ (font-family . roman)
+ (meta . ((interfaces . (font-interface
+ self-alignment-interface
+ side-position-interface text-interface
+ break-aligned-interface item-interface ))))
+ ))
(KeySignature
. (
@code{Axis_group_engraver}.
")
+(translator-property-description 'vocalName markup?
+ "Name of a vocal line.")
+(translator-property-description 'vocNam markup?
+ "Name of a vocal line, short version.")
+
(translator-property-description 'voltaOnThisStaff boolean?
"Normally, volta brackets are put only on the topmost staff. Setting
this variable to true, will force a bracket to be on this staff as
conversions.append (((2,1,14), conv, """style = dotted -> dash-fraction = 0"""))
+def conv (str):
+ str =re.sub (r'LyricsVoice\s*\.\s*instrument\s*=\s*("[^"]*")',
+ r'LyricsVoice . vocalName = \1', str)
+
+ str =re.sub (r'LyricsVoice\s*\.\s*instr\s*=\s*("[^"]*")',
+ r'LyricsVoice . vocNam = \1', str)
+ return str
+
+conversions.append (((2,1,15), conv, """LyricsVoice . instr(ument) -> vocalName"""))
+
################################
# END OF CONVERSIONS
################################