SectorZone: add attribute arc_boundary
[xcsoar.git] / src / Waypoint / WaypointList.cpp
blob7559e8620c87814beacbf12e236e7b2704599194
1 /*
2 Copyright_License {
4 XCSoar Glide Computer - http://www.xcsoar.org/
5 Copyright (C) 2000-2013 The XCSoar Project
6 A detailed list of copyright holders can be found in the file "AUTHORS".
8 This program is free software; you can redistribute it and/or
9 modify it under the terms of the GNU General Public License
10 as published by the Free Software Foundation; either version 2
11 of the License, or (at your option) any later version.
13 This program is distributed in the hope that it will be useful,
14 but WITHOUT ANY WARRANTY; without even the implied warranty of
15 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
16 GNU General Public License for more details.
18 You should have received a copy of the GNU General Public License
19 along with this program; if not, write to the Free Software
20 Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
24 #include "WaypointList.hpp"
25 #include "Waypoint/Waypoint.hpp"
27 #include <algorithm>
29 void
30 WaypointListItem::ResetVector()
32 vec.SetInvalid();
35 const GeoVector &
36 WaypointListItem::GetVector(const GeoPoint &location) const
38 if (!vec.IsValid())
39 vec = GeoVector(location, waypoint->location);
41 return vec;
44 class WaypointDistanceCompare
46 const GeoPoint &location;
48 public:
49 WaypointDistanceCompare(const GeoPoint &_location):location(_location) {}
51 bool operator()(const WaypointListItem &a,
52 const WaypointListItem &b) const {
53 return a.GetVector(location).distance < b.GetVector(location).distance;
57 void WaypointList::SortByDistance(const GeoPoint &location) {
58 std::sort(begin(), end(), WaypointDistanceCompare(location));