source file of the GNU LilyPond music typesetter
- (c) 2003 Juergen Reuter <reuter@ipd.uka.de>
+ (c) 2003 Juergen Reuter <reuter@ipd.uka.de>
*/
#include "gregorian-ligature-engraver.hh"
#include "staff-symbol-referencer.hh"
#include "font-interface.hh"
#include "warn.hh"
-#include "paper-def.hh"
+#include "output-def.hh"
#include "paper-column.hh"
/*
Real thickness);
public:
- TRANSLATOR_DECLARATIONS(Vaticana_ligature_engraver);
+ TRANSLATOR_DECLARATIONS (Vaticana_ligature_engraver);
protected:
virtual Spanner *create_ligature_spanner ();
Spanner *
Vaticana_ligature_engraver::create_ligature_spanner ()
{
- return make_spanner ("VaticanaLigature");
+ return make_spanner ("VaticanaLigature", SCM_EOL);
}
bool
dynamic_cast<Item*> (primitives[0].grob_)->get_column ();
Real join_thickness =
- thickness * column->get_paper ()->get_realvar (ly_symbol2scm ("linethickness"));
+ thickness * column->get_paper ()->get_dimension (ly_symbol2scm ("linethickness"));
/*
* Amount of extra space two put between some particular
{
Item *primitive = dynamic_cast<Item*> (primitives[i].grob_);
int prefix_set =
- gh_scm2int (primitive->get_grob_property ("prefix-set"));
+ scm_to_int (primitive->get_property ("prefix-set"));
int context_info =
- gh_scm2int (primitive->get_grob_property ("context-info"));
+ scm_to_int (primitive->get_property ("context-info"));
/*
* Get glyph_name, delta_pitch and context_info for this head.
*/
- SCM glyph_name_scm = primitive->get_grob_property ("glyph-name");
+ SCM glyph_name_scm = primitive->get_property ("glyph-name");
if (glyph_name_scm == SCM_EOL)
{
primitive->programming_error ("Vaticana_ligature:"
int delta_pitch = 0;
if (prev_primitive) /* urgh, need prev_primitive only here */
{
- SCM delta_pitch_scm = prev_primitive->get_grob_property ("delta-pitch");
+ SCM delta_pitch_scm = prev_primitive->get_property ("delta-pitch");
if (delta_pitch_scm != SCM_EOL)
{
- delta_pitch = gh_scm2int (delta_pitch_scm);
+ delta_pitch = scm_to_int (delta_pitch_scm);
}
else
{
/*
* Save the head's final x-offset.
*/
- primitive->set_grob_property ("x-offset",
- gh_double2scm (x_offset));
+ primitive->set_property ("x-offset",
+ scm_make_real (x_offset));
/*
* If the head is the 2nd head of a pes or flexa (but not a
}
else
{
- prev_primitive->set_grob_property ("add-join",
- gh_bool2scm(true));
+ prev_primitive->set_property ("add-join",
+ ly_bool2scm (true));
/*
* Create a small overlap of adjacent heads so that the join
check_for_prefix_loss (Item *primitive)
{
int prefix_set =
- gh_scm2int (primitive->get_grob_property ("prefix-set"));
+ scm_to_int (primitive->get_property ("prefix-set"));
if (prefix_set & ~PES_OR_FLEXA)
{
String prefs = Gregorian_ligature::prefixes_to_str (primitive);
- primitive->warning (_f ("ignored prefix(es) `%s' of this head according "
+ primitive->warning (_f ("ignored prefix (es) `%s' of this head according "
"to restrictions of the selected ligature style",
prefs.to_str0 ()));
}
Vaticana_ligature_engraver::transform_heads (Spanner *ligature,
Array<Grob_info> primitives)
{
- Real flexa_width= robust_scm2double ( ligature->get_grob_property ("flexa-width"), 2);
+ Real flexa_width= robust_scm2double ( ligature->get_property ("flexa-width"), 2);
- Real thickness= robust_scm2double ( ligature->get_grob_property ("thickness"), 1);
+ Real thickness= robust_scm2double ( ligature->get_property ("thickness"), 1);
Item *prev_primitive = 0;
int prev_prefix_set = 0;
int prev_context_info = 0;
int prev_delta_pitch = 0;
String prev_glyph_name = "";
- for (int i = 0; i < primitives.size(); i++) {
+ for (int i = 0; i < primitives.size (); i++) {
Item *primitive = dynamic_cast<Item*> (primitives[i].grob_);
int delta_pitch;
- SCM delta_pitch_scm = primitive->get_grob_property ("delta-pitch");
+ SCM delta_pitch_scm = primitive->get_property ("delta-pitch");
if (delta_pitch_scm != SCM_EOL)
{
- delta_pitch = gh_scm2int (delta_pitch_scm);
+ delta_pitch = scm_to_int (delta_pitch_scm);
}
else
{
/* retrieve & complete prefix_set and context_info */
int prefix_set =
- gh_scm2int (primitive->get_grob_property ("prefix-set"));
+ scm_to_int (primitive->get_property ("prefix-set"));
int context_info =
- gh_scm2int (primitive->get_grob_property ("context-info"));
+ scm_to_int (primitive->get_property ("context-info"));
if (is_stacked_head (prefix_set, context_info))
{
context_info |= STACKED_HEAD;
- primitive->set_grob_property ("context-info",
- gh_int2scm (context_info));
+ primitive->set_property ("context-info",
+ scm_int2num (context_info));
}
/*
String glyph_name;
if (prefix_set & VIRGA)
{
- glyph_name = "vaticana_punctum";
- primitive->set_grob_property ("add-stem", gh_bool2scm(true));
+ glyph_name = "vaticana-punctum";
+ primitive->set_property ("add-stem", ly_bool2scm (true));
}
else if (prefix_set & QUILISMA)
- glyph_name = "vaticana_quilisma";
+ glyph_name = "vaticana-quilisma";
else if (prefix_set & ORISCUS)
- glyph_name = "solesmes_oriscus";
+ glyph_name = "solesmes-oriscus";
else if (prefix_set & STROPHA)
if (prefix_set & AUCTUM)
- glyph_name = "solesmes_stropha_aucta";
- else glyph_name = "solesmes_stropha";
+ glyph_name = "solesmes-stropha-aucta";
+ else glyph_name = "solesmes-stropha";
else if (prefix_set & INCLINATUM)
if (prefix_set & AUCTUM)
- glyph_name = "solesmes_incl_auctum";
+ glyph_name = "solesmes-incl-auctum";
else if (prefix_set & DEMINUTUM)
- glyph_name = "solesmes_incl_parvum";
+ glyph_name = "solesmes-incl-parvum";
else
- glyph_name = "vaticana_inclinatum";
+ glyph_name = "vaticana-inclinatum";
else if (prefix_set & DEMINUTUM)
if (i == 0)
{
// initio debilis
- glyph_name = "vaticana_reverse_plica";
+ glyph_name = "vaticana-reverse-plica";
}
else if (prev_delta_pitch > 0)
{
if (!(prev_context_info & FLEXA_RIGHT))
/* correct head of previous primitive */
if (prev_delta_pitch > 1)
- prev_glyph_name = "vaticana_epiphonus";
+ prev_glyph_name = "vaticana-epiphonus";
else
- prev_glyph_name = "vaticana_vepiphonus";
- glyph_name = "vaticana_plica";
+ prev_glyph_name = "vaticana-vepiphonus";
+ glyph_name = "vaticana-plica";
}
else // (prev_delta_pitch <= 0)
{
if (i > 1)
{
/* cephalicus head with fixed size cauda */
- prev_glyph_name = "vaticana_inner_cephalicus";
+ prev_glyph_name = "vaticana-inner-cephalicus";
}
else
{
/* cephalicus head without cauda */
- prev_glyph_name = "vaticana_cephalicus";
+ prev_glyph_name = "vaticana-cephalicus";
}
/*
* Therefore, the following line of code should be
* placed somewhere else.
*/
- prev_primitive->set_grob_property ("add-cauda",
- gh_bool2scm(false));
+ prev_primitive->set_property ("add-cauda",
+ ly_bool2scm (false));
}
- glyph_name = "vaticana_reverse_plica";
+ glyph_name = "vaticana-reverse-plica";
}
else if (prefix_set & (CAVUM | LINEA))
if ((prefix_set & CAVUM) && (prefix_set & LINEA))
- glyph_name = "vaticana_linea_punctum_cavum";
+ glyph_name = "vaticana-linea-punctum-cavum";
else if (prefix_set & CAVUM)
- glyph_name = "vaticana_punctum_cavum";
+ glyph_name = "vaticana-punctum-cavum";
else
- glyph_name = "vaticana_linea_punctum";
+ glyph_name = "vaticana-linea-punctum";
else if (prefix_set & AUCTUM)
if (prefix_set & ASCENDENS)
- glyph_name = "solesmes_auct_asc";
+ glyph_name = "solesmes-auct-asc";
else
- glyph_name = "solesmes_auct_desc";
+ glyph_name = "solesmes-auct-desc";
else if ((context_info & STACKED_HEAD) &&
(context_info & PES_UPPER))
if (prev_delta_pitch > 1)
- glyph_name = "vaticana_upes";
+ glyph_name = "vaticana-upes";
else
- glyph_name = "vaticana_vupes";
+ glyph_name = "vaticana-vupes";
else
- glyph_name = "vaticana_punctum";
+ glyph_name = "vaticana-punctum";
/*
* This head needs a cauda, if it starts a flexa, is not the upper
* head of a pes, and if it is a punctum.
*/
if ((context_info & FLEXA_LEFT) && !(context_info & PES_UPPER))
- if (!String::compare (glyph_name, "vaticana_punctum"))
- primitive->set_grob_property ("add-cauda", gh_bool2scm(true));
+ if (!String::compare (glyph_name, "vaticana-punctum"))
+ primitive->set_property ("add-cauda", ly_bool2scm (true));
/*
* Execptional rule for porrectus:
{
check_for_prefix_loss (prev_primitive);
prev_glyph_name = "flexa";
- prev_primitive->set_grob_property ("flexa-height",
- gh_int2scm (prev_delta_pitch));
- prev_primitive->set_grob_property ("flexa-width",
- gh_double2scm (flexa_width));
+ prev_primitive->set_property ("flexa-height",
+ scm_int2num (prev_delta_pitch));
+ prev_primitive->set_property ("flexa-width",
+ scm_make_real (flexa_width));
bool add_cauda = !(prev_prefix_set && PES_OR_FLEXA);
- prev_primitive->set_grob_property ("add-cauda",
- gh_bool2scm (add_cauda));
+ prev_primitive->set_property ("add-cauda",
+ ly_bool2scm (add_cauda));
check_for_prefix_loss (primitive);
glyph_name = "";
- primitive->set_grob_property ("flexa-width",
- gh_double2scm (flexa_width));
+ primitive->set_property ("flexa-width",
+ scm_make_real (flexa_width));
}
/*
{
if ((context_info & PES_UPPER) && (context_info & STACKED_HEAD))
{
- if (!String::compare (prev_glyph_name, "vaticana_punctum"))
+ if (!String::compare (prev_glyph_name, "vaticana-punctum"))
if (prev_delta_pitch > 1)
- prev_glyph_name = "vaticana_lpes";
+ prev_glyph_name = "vaticana-lpes";
else
- prev_glyph_name = "vaticana_vlpes";
+ prev_glyph_name = "vaticana-vlpes";
}
}
if (prev_primitive)
- prev_primitive->set_grob_property ("glyph-name",
- scm_makfrom0str (prev_glyph_name.to_str0 ()));
+ prev_primitive->set_property ("glyph-name",
+ scm_makfrom0str (prev_glyph_name.to_str0 ()));
/*
* In the backend, flexa shapes and joins need to know about line
* ligature grob's value for thickness to each ligature head (even
* if not all of them need to know).
*/
- primitive->set_grob_property ("thickness", gh_double2scm (thickness));
+ primitive->set_property ("thickness", scm_make_real (thickness));
prev_primitive = primitive;
prev_prefix_set = prefix_set;
prev_glyph_name = glyph_name;
}
- prev_primitive->set_grob_property ("glyph-name",
- scm_makfrom0str (prev_glyph_name.to_str0 ()));
+ prev_primitive->set_property ("glyph-name",
+ scm_makfrom0str (prev_glyph_name.to_str0 ()));
#if 0
Real ligature_width =
align_heads (primitives, flexa_width, thickness);
#if 0 // experimental code to collapse spacing after ligature
- /* TODO: set to max(old/new spacing-increment), since other
+ /* TODO: set to max (old/new spacing-increment), since other
voices/staves also may want to set this property. */
Item *first_primitive = dynamic_cast<Item*> (primitives[0].grob_);
- Paper_column *paper_column = first_primitive->get_column();
+ Paper_column *paper_column = first_primitive->get_column ();
paper_column->warning (_f ("Vaticana_ligature_engraver: "
"setting `spacing-increment = %f': ptr=%ul",
ligature_width, paper_column));
paper_column->
- set_grob_property("forced-spacing", gh_double2scm (ligature_width));
+ set_property ("forced-spacing", scm_make_real (ligature_width));
#endif
}