"beam",
"crescendo",
"decrescendo",
+ "rest",
"slur",
0
};
Voice_devnull_engraver::try_music (Music *m)
{
SCM s = get_property ("devNullVoice");
+
#if 0
/* No need */
if (gh_equal_p (s, ly_symbol2scm ("never")))
return;
#endif
- if (gh_equal_p (s, ly_symbol2scm ("allways"))
+ if (gh_equal_p (s, ly_symbol2scm ("always"))
|| (s == SCM_EOL
- && daddy_trans_l_->id_str_.left_str (3) == "two"
+ && daddy_trans_->id_string_.left_string (3) == "two"
&& (to_boolean (get_property ("unison"))
|| to_boolean (get_property ("unisilence")))))
{
for (char const **p = eat_spanners; *p; p++)
{
- if (t == ly_str02scm (*p))
+ if (t == scm_makfrom0str (*p))
return true;
}
}
return;
#endif
- if (s == ly_symbol2scm ("allways")
+#if 0 /* We used to have have this until 1.5.68. Not sure about
+ soloADue requirement */
+ if (s == ly_symbol2scm ("always")
|| (s == SCM_EOL
- && daddy_trans_l_->id_str_.left_str (3) == "two"
+ && daddy_trans_->id_string_.left_string (3) == "two"
&& (to_boolean (get_property ("unison"))
|| to_boolean (get_property ("unisilence")))))
+#else
+ if (s == ly_symbol2scm ("always")
+ || (s == SCM_EOL
+ && to_boolean (get_property ("soloADue"))
+ && ((daddy_trans_->id_string_.left_string (3) == "two"
+ && (to_boolean (get_property ("unison"))
+ || to_boolean (get_property ("unisilence"))))
+
+ /* Maybe this should be optional? */
+ || to_boolean (get_property ("othersolo")))))
+#endif
+
for (char const **p = junk_interfaces; *p; p++)
- if (i.grob_l_->internal_has_interface (ly_symbol2scm (*p)))
+ if (i.grob_->internal_has_interface (ly_symbol2scm (*p)))
{
- /* Ugh, we can suicide them, but they remain living */
- i.grob_l_->suicide ();
+ i.grob_->suicide ();
return;
}
}
ENTER_DESCRIPTION(Voice_devnull_engraver,
/* descr */ "Kill off certain items and spanners if we're Voice `two' and unison or unisilence is set.",
/* creats*/ "",
-/* acks */ "grob-interface",
+/* accepts */ "general-music",
+/* acks */ "grob-interface",
/* reads */ "",
/* write */ "");