-\header {
- filename = "praeludium-fuga-E.ly";
- title = "praeludium and fuga in E-major";
- opus = "BWV 566";
- composer = "Johann Sebastian Bach (1685-1750)";
- enteredby = "JCN";
- copyright = "public domain";
-}
-%{
- description
-
- Praeludium 3 bar excerpt,
- 2nd fuga transposed subject -- 4 bar excerpt.
- We try to imitate the Griepenkerl/Keller edition which
- gives the best approximation to Bach's original layout
-
-%}
-%{
- Tested Features:
- purpose of this file is testing:
- * real-life collisions
- * multi-voice input --- splitting?
- * organ staff...
-%}
-
-\version "1.3.4";
-
-
praeludium_commands = \notes {
\time 4/4;
else if (dynamic_cast<Bar *> (info.elem_l_)
&& accidental_idx_arr_.size ())
{
- bool def = (!item_p_);
create_key ();
- if (!def)
- {
- item_p_->set_elt_property ("visibility-lambda",
- scm_eval (ly_symbol2scm ("all-visible")));
- }
}
}
{
if (item_p_)
{
+ if (keyreq_l_)
+ item_p_->set_elt_property ("visibility-lambda",
+ scm_eval (ly_symbol2scm ("all-visible")));
+
typeset_element (item_p_);
item_p_ = 0;
}
/*
- TODO Slightly hairy.
+ TODO. Use properties; and this is too hairy.
*/
void
Key_engraver::read_req (Key_change_req const * r)
#include "paper-column.hh"
#include "paper-def.hh"
-/*
- TODO: rename this to system-open-engraver (or whatever.)
-
- */
class System_start_delimiter_engraver : public Engraver
{
public:
VIRTUAL_COPY_CONS(Translator);
System_start_delimiter_engraver();
- Spanner * spanbar_;
protected:
-
+ Spanner * delim_;
virtual void acknowledge_element (Score_element_info);
virtual void do_creation_processing ();
virtual void do_removal_processing ();
ADD_THIS_TRANSLATOR(System_start_delimiter_engraver);
-
void
System_start_delimiter_engraver::acknowledge_element (Score_element_info inf)
{
if (dynamic_cast<Staff_symbol*> (inf.elem_l_))
{
/*
- don't add as Axis_group_interface (spanbar_).add_element (),
+ don't add as Axis_group_interface (delim_).add_element (),
because that would set the parent as well */
- Group_interface (spanbar_).add_element (inf.elem_l_);
+ Group_interface (delim_).add_element (inf.elem_l_);
}
else if (System_start_delimiter * b = dynamic_cast<System_start_delimiter *> (inf.elem_l_))
{
SCM gl = b->get_elt_property ("glyph");
- SCM my_gl = get_property ("spanBarGlyph");
+ SCM my_gl = delim_->get_elt_property ("glyph");
/*
UGH UGH
System_start_delimiter_engraver::System_start_delimiter_engraver()
{
- spanbar_ = 0;
+ delim_ = 0;
}
void
System_start_delimiter_engraver::do_creation_processing()
{
- spanbar_ = new System_start_delimiter;
- spanbar_->set_bound (LEFT, get_staff_info ().command_pcol_l ());
- announce_element (Score_element_info (spanbar_,0));
-}
+ delim_ = new System_start_delimiter;
+ delim_->set_bound (LEFT, get_staff_info ().command_pcol_l ());
-void
-System_start_delimiter_engraver::do_removal_processing ()
-{
+ /*
+ You can't override the glyph using \property, you must do it in
+ the predefined context (ie. \translator { ... } )
+ */
SCM s = get_property ("systemStartDelimiterGlyph");
if (gh_symbol_p (s))
{
- spanbar_->set_elt_property ("glyph", s);
+ delim_->set_elt_property ("glyph", s);
}
+ announce_element (Score_element_info (delim_,0));
+}
+
+void
+System_start_delimiter_engraver::do_removal_processing ()
+{
// ugh, should have naming without bracket
SCM collapse = get_property ("bracketCollapseHeight");
if (gh_number_p (collapse))
- spanbar_->set_elt_property ("collapse-height", collapse);
+ delim_->set_elt_property ("collapse-height", collapse);
else
- spanbar_->set_elt_property ("collapse-height", gh_double2scm (1));
+ delim_->set_elt_property ("collapse-height", gh_double2scm (1));
- spanbar_->set_bound (RIGHT, get_staff_info ().command_pcol_l ());
- typeset_element (spanbar_);
+ delim_->set_bound (RIGHT, get_staff_info ().command_pcol_l ());
+ typeset_element (delim_);
}