+/*
+ local-key-item.cc -- implement Local_key_item, Local_acc
+
+ source file of the LilyPond music typesetter
+
+ (c) 1997 Han-Wen Nienhuys <hanwen@stack.nl>
+*/
+
#include "local-key-item.hh"
#include "molecule.hh"
#include "scalar.hh"
{
add(m_l->octave_i_, m_l->notename_i_, m_l->accidental_i_);
}
+
void
Local_key_item::add (int o, int p , int a)
{
Local_acc l;
- l.octave = o;
- l.name = p;
- l.acc = a;
+ l.octave_i_ = o;
+ l.name_i_ = p;
+ l.accidental_i_ = a;
+ for (int i=0; i< accs.size(); i++)
+ if (!Local_acc::compare(l, accs[i]))
+ return;
+
accs.push(l);
}
int lastoct = -100;
for (int i = 0; i < accs.size(); i++) {
// do one octave
- if (accs[i].octave != lastoct) {
+ if (accs[i].octave_i_ != lastoct) {
if (octmol){
Real dy =lastoct*7*paper()->internote();
octmol->translate(Offset(0, dy));
}
octmol= new Molecule;
}
- lastoct = accs[i].octave;
- Symbol s =paper()->lookup_l()->accidental(accs[i].acc);
+ lastoct = accs[i].octave_i_;
+ Symbol s =paper()->lookup_l()->accidental(accs[i].accidental_i_);
Atom a(s);
- Real dy = (accs[i].name + c0_position) * paper()->internote();
+ Real dy = (accs[i].name_i_ + c0_position) * paper()->internote();
a.translate(Offset(0,dy));
octmol->add_right(a);
int
Local_acc::compare(Local_acc&a, Local_acc&b)
{
- if (a.octave - b.octave)
- return a.octave - b.octave;
- if (a.name - b.name)
- return a.name - b.name;
+ if (a.octave_i_ - b.octave_i_)
+ return a.octave_i_ - b.octave_i_;
+ if (a.name_i_ - b.name_i_)
+ return a.name_i_ - b.name_i_;
- assert(false);
+ return a.accidental_i_ - b.accidental_i_;
};
IMPLEMENT_STATIC_NAME(Local_key_item);