X-Git-Url: https://git.donarmstrong.com/?a=blobdiff_plain;f=lily%2Fpitch-interval.cc;h=8c70cf4a09f1dee81582e7608b05ff374d4ace73;hb=0387f04497978e37b335a8b99eec905499d6ad0f;hp=069c86b7848871d2da25546d95706c013540dff1;hpb=e24df7c27635dc996c466295eacf2981bddccaf7;p=lilypond.git diff --git a/lily/pitch-interval.cc b/lily/pitch-interval.cc index 069c86b784..8c70cf4a09 100644 --- a/lily/pitch-interval.cc +++ b/lily/pitch-interval.cc @@ -1,10 +1,9 @@ -/* - pitch-interval.cc -- implement Pitch_interval - +/* + pitch-interval.cc -- implement Pitch_interval + source file of the GNU LilyPond music typesetter - - (c) 2004--2005 Han-Wen Nienhuys - + + (c) 2004--2008 Han-Wen Nienhuys */ #include "pitch-interval.hh" @@ -13,30 +12,71 @@ Pitch_interval::Pitch_interval (Pitch p1, Pitch p2) { - elem_ref(LEFT) = p1; - elem_ref(RIGHT) = p2; + at (LEFT) = p1; + at (RIGHT) = p2; } - Pitch_interval::Pitch_interval () { - elem_ref(LEFT) = Pitch (100,0,0); - elem_ref(RIGHT) = Pitch (-100,0,0); + at (LEFT) = Pitch (100, 0, 0); + at (RIGHT) = Pitch (-100, 0, 0); } - bool Pitch_interval::is_empty () const { - return elem(LEFT) > elem(RIGHT); + return at (LEFT) > at (RIGHT); } - -void +Drul_array Pitch_interval::add_point (Pitch p) { - if (elem_ref(LEFT) > p) - elem_ref(LEFT) = p; - if (elem_ref(RIGHT) < p) - elem_ref(RIGHT) = p; + Drul_array expansions(false,false); + if (at (LEFT).tone_pitch () > p.tone_pitch ()) + { + at (LEFT) = p; + expansions [LEFT] = true; + } + if (at (RIGHT).tone_pitch () < p.tone_pitch ()) + { + at (RIGHT) = p; + expansions [RIGHT] = true; + } + return expansions; +} + + +Pitch_lexicographic_interval::Pitch_lexicographic_interval (Pitch p1, Pitch p2) +{ + at (LEFT) = p1; + at (RIGHT) = p2; +} + +Pitch_lexicographic_interval::Pitch_lexicographic_interval () +{ + at (LEFT) = Pitch (100, 0, 0); + at (RIGHT) = Pitch (-100, 0, 0); +} + +bool +Pitch_lexicographic_interval::is_empty () const +{ + return at (LEFT) > at (RIGHT); +} + +Drul_array +Pitch_lexicographic_interval::add_point (Pitch p) +{ + Drul_array expansions(false,false); + if (at (LEFT) > p) + { + at (LEFT) = p; + expansions [LEFT] = true; + } + if (at (RIGHT) < p) + { + at (RIGHT) = p; + expansions [RIGHT] = true; + } + return expansions; }