X-Git-Url: https://main.carlh.net/gitweb/?a=blobdiff_plain;f=gtk2_ardour%2Ftime_selection.cc;h=2f40dcb8e4afe0a06c80f963193fa94660bb1caf;hb=1a7fd81f4095e3ee8cb42e63c232a51529412846;hp=551e8611765f26520b5365772a2a30b513fe1b24;hpb=209d967b1bb80a9735d690d8f4f0455ecb9970ca;p=ardour.git diff --git a/gtk2_ardour/time_selection.cc b/gtk2_ardour/time_selection.cc index 551e861176..2f40dcb8e4 100644 --- a/gtk2_ardour/time_selection.cc +++ b/gtk2_ardour/time_selection.cc @@ -1,5 +1,5 @@ /* - Copyright (C) 2003-2004 Paul Davis + Copyright (C) 2003-2004 Paul Davis This program is free software; you can redistribute it and/or modify it under the terms of the GNU General Public License as published by @@ -15,19 +15,19 @@ along with this program; if not, write to the Free Software Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA. - $Id$ */ #include -#include -#include +#include "pbd/error.h" +#include "ardour/types.h" #include "time_selection.h" -#include "i18n.h" +#include "pbd/i18n.h" using namespace ARDOUR; +using namespace PBD; AudioRange& TimeSelection::operator[] (uint32_t which) @@ -37,8 +37,8 @@ TimeSelection::operator[] (uint32_t which) return *i; } } - fatal << compose (_("programming error: request for non-existent audio range (%1)!"), which) << endmsg; - /*NOTREACHED*/ + fatal << string_compose (_("programming error: request for non-existent audio range (%1)!"), which) << endmsg; + abort(); /*NOTREACHED*/ return *(new AudioRange(0,0,0)); /* keep the compiler happy; never called */ } @@ -55,9 +55,9 @@ TimeSelection::consolidate () continue; } - if ((*a).coverage ((*b).start, (*b).end) != OverlapNone) { - (*a).start = std::min ((*a).start, (*b).start); - (*a).end = std::max ((*a).end, (*b).end); + if (a->coverage (b->start, b->end) != Evoral::OverlapNone) { + a->start = std::min (a->start, b->start); + a->end = std::max (a->end, b->end); erase (b); changed = true; goto restart; @@ -66,16 +66,16 @@ TimeSelection::consolidate () } return changed; -} +} -jack_nframes_t +framepos_t TimeSelection::start () { if (empty()) { return 0; } - jack_nframes_t first = max_frames; + framepos_t first = max_framepos; for (std::list::iterator i = begin(); i != end(); ++i) { if ((*i).start < first) { @@ -85,10 +85,10 @@ TimeSelection::start () return first; } -jack_nframes_t +framepos_t TimeSelection::end_frame () { - jack_nframes_t last = 0; + framepos_t last = 0; /* XXX make this work like RegionSelection: no linear search needed */ @@ -100,9 +100,12 @@ TimeSelection::end_frame () return last; } -jack_nframes_t +framecnt_t TimeSelection::length() { + if (empty()) { + return 0; + } + return end_frame() - start() + 1; } -