2
* Copyright © 2012-2013 Canonical Ltd.
4
* This program is free software: you can redistribute it and/or modify it
5
* under the terms of the GNU Lesser General Public License version 3,
6
* as published by the Free Software Foundation.
8
* This program is distributed in the hope that it will be useful,
9
* but WITHOUT ANY WARRANTY; without even the implied warranty of
10
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
11
* GNU Lesser General Public License for more details.
13
* You should have received a copy of the GNU Lesser General Public License
14
* along with this program. If not, see <http://www.gnu.org/licenses/>.
16
* Authored by: Thomas Voß <thomas.voss@canonical.com>
18
#ifndef LOCATION_WGS84_LONGITUDE_H_
19
#define LOCATION_WGS84_LONGITUDE_H_
21
#include <location/units/units.h>
22
#include <location/wgs84/coordinate.h>
34
typedef Coordinate<tag::Longitude, units::PlaneAngle> Longitude;
37
struct CoordinateTraits<Longitude>
48
static void check_and_throw_if_invalid(const typename Longitude::Quantity& coordinate)
50
if (coordinate.value() < min())
51
throw std::out_of_range(u8"Longitude(coordinate.value() < min())");
52
if (coordinate.value() > max())
53
throw std::out_of_range(u8"Longitude(coordinate.value() > max())");
59
#endif // LOCATION_WGS84_LATITUDE_H_