X-Git-Url: https://git.donarmstrong.com/?a=blobdiff_plain;f=lily%2Fpitch-interval.cc;h=3a5670be501379d340f5b54102137a40afa1aca0;hb=97a0169312a260933246ab224e4f8b0969871dd5;hp=3043bbff07a8f9c5bec36394175da7bc71c386a2;hpb=12f6dc265020fd98dcb3938b4856272b7b24a76e;p=lilypond.git diff --git a/lily/pitch-interval.cc b/lily/pitch-interval.cc index 3043bbff07..3a5670be50 100644 --- a/lily/pitch-interval.cc +++ b/lily/pitch-interval.cc @@ -1,9 +1,20 @@ /* - pitch-interval.cc -- implement Pitch_interval + This file is part of LilyPond, the GNU music typesetter. - source file of the GNU LilyPond music typesetter + Copyright (C) 2004--2015 Han-Wen Nienhuys - (c) 2004--2007 Han-Wen Nienhuys + LilyPond is free software: you can redistribute it and/or modify + it under the terms of the GNU General Public License as published by + the Free Software Foundation, either version 3 of the License, or + (at your option) any later version. + + LilyPond is distributed in the hope that it will be useful, + but WITHOUT ANY WARRANTY; without even the implied warranty of + MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the + GNU General Public License for more details. + + You should have received a copy of the GNU General Public License + along with LilyPond. If not, see . */ #include "pitch-interval.hh" @@ -18,8 +29,8 @@ Pitch_interval::Pitch_interval (Pitch p1, Pitch p2) Pitch_interval::Pitch_interval () { - at (LEFT) = Pitch (100, 0, 0); - at (RIGHT) = Pitch (-100, 0, 0); + at (LEFT) = Pitch (100, 0); + at (RIGHT) = Pitch (-100, 0); } bool @@ -28,29 +39,23 @@ Pitch_interval::is_empty () const return at (LEFT) > at (RIGHT); } -Direction +Drul_array Pitch_interval::add_point (Pitch p) { - if (is_empty()) - { - at (LEFT) = at (RIGHT) = p; - return CENTER; - } - else if (at (LEFT).tone_pitch () > p.tone_pitch ()) + Drul_array expansions (false, false); + if (at (LEFT).tone_pitch () > p.tone_pitch ()) { at (LEFT) = p; - return LEFT; + expansions [LEFT] = true; } - else if (at (RIGHT).tone_pitch () < p.tone_pitch ()) + if (at (RIGHT).tone_pitch () < p.tone_pitch ()) { at (RIGHT) = p; - return RIGHT; + expansions [RIGHT] = true; } - else - return CENTER; + return expansions; } - Pitch_lexicographic_interval::Pitch_lexicographic_interval (Pitch p1, Pitch p2) { at (LEFT) = p1; @@ -59,8 +64,8 @@ Pitch_lexicographic_interval::Pitch_lexicographic_interval (Pitch p1, Pitch p2) Pitch_lexicographic_interval::Pitch_lexicographic_interval () { - at (LEFT) = Pitch (100, 0, 0); - at (RIGHT) = Pitch (-100, 0, 0); + at (LEFT) = Pitch (100, 0); + at (RIGHT) = Pitch (-100, 0); } bool @@ -69,24 +74,19 @@ Pitch_lexicographic_interval::is_empty () const return at (LEFT) > at (RIGHT); } -Direction +Drul_array Pitch_lexicographic_interval::add_point (Pitch p) { - if (is_empty()) - { - at (LEFT) = at (RIGHT) = p; - return CENTER; - } - else if (at (LEFT) > p) + Drul_array expansions (false, false); + if (at (LEFT) > p) { at (LEFT) = p; - return LEFT; + expansions [LEFT] = true; } - else if (at (RIGHT) < p) + if (at (RIGHT) < p) { at (RIGHT) = p; - return RIGHT; + expansions [RIGHT] = true; } - else - return CENTER; + return expansions; }