/* This file is part of LilyPond, the GNU music typesetter. Copyright (C) 1996--2014 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 . */ #ifndef INTERVAL_TCC #define INTERVAL_TCC #include #include "interval.hh" #include "std-string.hh" // MacOS 10.3 problems: // #include using namespace std; template int _Interval__compare (const Interval_t &a, Interval_t const &b) { if (a.at (LEFT) == b.at (LEFT) && a.at (RIGHT) == b.at (RIGHT)) return 0; if (a.at (LEFT) <= b.at (LEFT) && a.at (RIGHT) >= b.at (RIGHT)) return 1; if (a.at (LEFT) >= b.at (LEFT) && a.at (RIGHT) <= b.at (RIGHT)) return -1; return -2; } template bool Interval_t::superset (Interval_t const &a) const { int c_i = _Interval__compare (*this, a); if (c_i == -2) return false; return c_i >= 0; } template int Interval__compare (Interval_t const &a, Interval_t const &b) { int i = _Interval__compare (a, b); if (i < -1) assert (false); return i; } template void Interval_t::set_empty () { at (LEFT) = (T) infinity (); at (RIGHT) = (T) - infinity (); } template void Interval_t::set_full () { at (LEFT) = (T) - infinity (); at (RIGHT) = (T) infinity (); } template T Interval_t::length () const { if (at (RIGHT) <= at (LEFT)) return 0; else return at (RIGHT) - at (LEFT); } template T Interval_t::delta () const { return at (RIGHT) - at (LEFT); } /* smallest Interval which includes *this and #h# */ template void Interval_t::unite (Interval_t h) { at (LEFT) = min (h.at (LEFT), at (LEFT)); at (RIGHT) = max (h.at (RIGHT), at (RIGHT)); } /* Unites h and this interval, but in such a way that h will lie in a particular direction from this interval, with a minimum amount of space in between. (That is, h will be translated before we unite, if that is necessary to prevent overlap. */ template void Interval_t::unite_disjoint (Interval_t h, T padding, Direction d) { T dir = d; T translation = dir * (at (d) + dir * padding - h.at (-d)); if (translation > (T) 0) h.translate (translation); unite (h); } template Interval_t Interval_t::union_disjoint (Interval_t h, T padding, Direction d) const { Interval_t iv = *this; iv.unite_disjoint (h, padding, d); return iv; } template void Interval_t::intersect (Interval_t h) { at (LEFT) = max (h.at (LEFT), at (LEFT)); at (RIGHT) = min (h.at (RIGHT), at (RIGHT)); } template string Interval_t::to_string () const { if (is_empty ()) return "[empty]"; string s ("["); return (s + T_to_string (at (LEFT)) + string (",") + T_to_string (at (RIGHT)) + string ("]")); } template bool Interval_t::contains (T r) const { return r >= at (LEFT) && r <= at (RIGHT); } #define INTERVAL__INSTANTIATE(T) struct Interval_t; \ template int Interval__compare (const Interval_t &, Interval_t const &) #endif // INTERVAL_TCC