lomiri-location-service ..
An aggregating location service providing positioning and geocoding capabilities to applications.
longitude.h
Go to the documentation of this file.
1/*
2 * Copyright © 2012-2013 Canonical Ltd.
3 *
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.
7 *
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.
12 *
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/>.
15 *
16 * Authored by: Thomas Voß <thomas.voss@canonical.com>
17 */
18#ifndef LOCATION_SERVICE_COM_LOMIRI_LOCATION_WGS84_LONGITUDE_H_
19#define LOCATION_SERVICE_COM_LOMIRI_LOCATION_WGS84_LONGITUDE_H_
20
23
24#include <stdexcept>
25
26namespace com
27{
28namespace lomiri
29{
30namespace location
31{
32namespace wgs84
33{
34namespace tag
35{
36struct Longitude;
37}
39
40template<>
42{
43 static double min()
44 {
45 return -180;
46 };
47 static double max()
48 {
49 return 180;
50 };
51
52 static void check_and_throw_if_invalid(const typename Longitude::Quantity& coordinate)
53 {
54 if (coordinate.value() < min())
55 throw std::out_of_range(u8"Longitude(coordinate.value() < min())");
56 if (coordinate.value() > max())
57 throw std::out_of_range(u8"Longitude(coordinate.value() > max())");
58 }
59};
60}
61}
62}
63}
64#endif // LOCATION_SERVICE_COM_LOMIRI_LOCATION_WGS84_LATITUDE_H_
Coordinate< tag::Longitude, units::PlaneAngle > Longitude
Definition longitude.h:38
Definition accuracy.h:24
static void check_and_throw_if_invalid(const typename Longitude::Quantity &coordinate)
Definition longitude.h:52