Address PR comments

This commit is contained in:
Patrick Niklaus 2017-04-21 14:45:36 +00:00 committed by Patrick Niklaus
parent 8ec0745883
commit 0e39aa9488
4 changed files with 52 additions and 26 deletions

View File

@ -25,8 +25,8 @@ SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
*/
#ifndef ALIAS_HPP
#define ALIAS_HPP
#ifndef OSRM_UTIL_ALIAS_HPP
#define OSRM_UTIL_ALIAS_HPP
#include <functional>
#include <iostream>
@ -42,7 +42,7 @@ inline std::ostream &operator<<(std::ostream &stream, const Alias<From, Tag> &in
template <typename From, typename Tag> struct Alias final
{
using value_type = From;
static_assert(std::is_arithmetic<From>(), "");
static_assert(std::is_arithmetic<From>::value, "Needs to be based on an arithmetic type");
From __value;
friend std::ostream &operator<<<From, Tag>(std::ostream &stream, const Alias &inst);
@ -61,10 +61,12 @@ template <typename From, typename Tag> struct Alias final
{
return Alias{__value * static_cast<const From>(rhs_)};
}
inline Alias operator*(const double rhs_) const { return Alias{__value * rhs_}; }
inline Alias operator/(const Alias rhs_) const
{
return Alias{__value / static_cast<const From>(rhs_)};
}
inline Alias operator/(const double rhs_) const { return Alias{__value / rhs_}; }
inline Alias operator|(const Alias rhs_) const
{
return Alias{__value | static_cast<const From>(rhs_)};
@ -80,15 +82,47 @@ template <typename From, typename Tag> struct Alias final
inline bool operator==(const Alias z_) const { return __value == static_cast<const From>(z_); }
inline bool operator!=(const Alias z_) const { return __value != static_cast<const From>(z_); }
inline Alias operator++() { __value++; return *this; }
inline Alias operator--() { __value--; return *this; }
inline Alias operator++()
{
__value++;
return *this;
}
inline Alias operator--()
{
__value--;
return *this;
}
inline Alias operator+=(const Alias z_) { __value += static_cast<const From>(z_); return *this; }
inline Alias operator-=(const Alias z_) { __value -= static_cast<const From>(z_); return *this; }
inline Alias operator/=(const Alias z_) { __value /= static_cast<const From>(z_); return *this; }
inline Alias operator*=(const Alias z_) { __value *= static_cast<const From>(z_); return *this; }
inline Alias operator|=(const Alias z_) { __value |= static_cast<const From>(z_); return *this; }
inline Alias operator&=(const Alias z_) { __value &= static_cast<const From>(z_); return *this; }
inline Alias operator+=(const Alias z_)
{
__value += static_cast<const From>(z_);
return *this;
}
inline Alias operator-=(const Alias z_)
{
__value -= static_cast<const From>(z_);
return *this;
}
inline Alias operator/=(const Alias z_)
{
__value /= static_cast<const From>(z_);
return *this;
}
inline Alias operator*=(const Alias z_)
{
__value *= static_cast<const From>(z_);
return *this;
}
inline Alias operator|=(const Alias z_)
{
__value |= static_cast<const From>(z_);
return *this;
}
inline Alias operator&=(const Alias z_)
{
__value &= static_cast<const From>(z_);
return *this;
}
};
template <typename From, typename Tag>
@ -96,14 +130,6 @@ inline std::ostream &operator<<(std::ostream &stream, const Alias<From, Tag> &in
{
return stream << inst.__value;
}
template <typename T>
struct is_valid_alias
: std::integral_constant<bool,
std::is_trivial<T>::value && std::is_standard_layout<T>::value &&
std::is_pod<T>::value>
{
};
}
namespace std

View File

@ -59,10 +59,10 @@ using FixedLatitude = Alias<std::int32_t, tag::latitude>;
using FixedLongitude = Alias<std::int32_t, tag::longitude>;
using FloatLatitude = Alias<double, tag::latitude>;
using FloatLongitude = Alias<double, tag::longitude>;
static_assert(osrm::is_valid_alias<FixedLatitude>(), "FixedLatitude is not a valid alias");
static_assert(osrm::is_valid_alias<FixedLongitude>(), "FixedLongitude is not a valid alias");
static_assert(osrm::is_valid_alias<FloatLatitude>(), "FloatLatitude is not a valid alias");
static_assert(osrm::is_valid_alias<FloatLongitude>(), "FloatLongitude is not a valid alias");
static_assert(std::is_pod<FixedLatitude>(), "FixedLatitude is not a valid alias");
static_assert(std::is_pod<FixedLongitude>(), "FixedLongitude is not a valid alias");
static_assert(std::is_pod<FloatLatitude>(), "FloatLatitude is not a valid alias");
static_assert(std::is_pod<FloatLongitude>(), "FloatLongitude is not a valid alias");
/**
* Converts a typed latitude from floating to fixed representation.

View File

@ -47,9 +47,9 @@ struct osm_way_id
};
}
using OSMNodeID = osrm::Alias<std::uint64_t, tag::osm_node_id>;
static_assert(osrm::is_valid_alias<OSMNodeID>(), "OSMNodeID is not a valid alias");
static_assert(std::is_pod<OSMNodeID>(), "OSMNodeID is not a valid alias");
using OSMWayID = osrm::Alias<std::uint64_t, tag::osm_way_id>;
static_assert(osrm::is_valid_alias<OSMWayID>(), "OSMWayID is not a valid alias");
static_assert(std::is_pod<OSMWayID>(), "OSMWayID is not a valid alias");
static const OSMNodeID SPECIAL_OSM_NODEID = OSMNodeID{std::numeric_limits<std::uint64_t>::max()};
static const OSMWayID SPECIAL_OSM_WAYID = OSMWayID{std::numeric_limits<std::uint32_t>::max()};

View File

@ -4,11 +4,11 @@
#include "util/timing_util.hpp"
#include <algorithm>
#include <iomanip>
#include <numeric>
#include <random>
#include <string>
#include <vector>
#include <iomanip>
using namespace osrm;