Address PR comments
This commit is contained in:
parent
8ec0745883
commit
0e39aa9488
@ -25,8 +25,8 @@ SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
|||||||
|
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#ifndef ALIAS_HPP
|
#ifndef OSRM_UTIL_ALIAS_HPP
|
||||||
#define ALIAS_HPP
|
#define OSRM_UTIL_ALIAS_HPP
|
||||||
|
|
||||||
#include <functional>
|
#include <functional>
|
||||||
#include <iostream>
|
#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
|
template <typename From, typename Tag> struct Alias final
|
||||||
{
|
{
|
||||||
using value_type = From;
|
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;
|
From __value;
|
||||||
friend std::ostream &operator<<<From, Tag>(std::ostream &stream, const Alias &inst);
|
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_)};
|
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
|
inline Alias operator/(const Alias rhs_) const
|
||||||
{
|
{
|
||||||
return Alias{__value / static_cast<const From>(rhs_)};
|
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
|
inline Alias operator|(const Alias rhs_) const
|
||||||
{
|
{
|
||||||
return Alias{__value | static_cast<const From>(rhs_)};
|
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 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++()
|
||||||
inline Alias operator--() { __value--; return *this; }
|
{
|
||||||
|
__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_)
|
||||||
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; }
|
__value += static_cast<const From>(z_);
|
||||||
inline Alias operator*=(const Alias z_) { __value *= static_cast<const From>(z_); return *this; }
|
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>
|
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;
|
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
|
namespace std
|
||||||
|
@ -59,10 +59,10 @@ using FixedLatitude = Alias<std::int32_t, tag::latitude>;
|
|||||||
using FixedLongitude = Alias<std::int32_t, tag::longitude>;
|
using FixedLongitude = Alias<std::int32_t, tag::longitude>;
|
||||||
using FloatLatitude = Alias<double, tag::latitude>;
|
using FloatLatitude = Alias<double, tag::latitude>;
|
||||||
using FloatLongitude = Alias<double, tag::longitude>;
|
using FloatLongitude = Alias<double, tag::longitude>;
|
||||||
static_assert(osrm::is_valid_alias<FixedLatitude>(), "FixedLatitude is not a valid alias");
|
static_assert(std::is_pod<FixedLatitude>(), "FixedLatitude is not a valid alias");
|
||||||
static_assert(osrm::is_valid_alias<FixedLongitude>(), "FixedLongitude is not a valid alias");
|
static_assert(std::is_pod<FixedLongitude>(), "FixedLongitude is not a valid alias");
|
||||||
static_assert(osrm::is_valid_alias<FloatLatitude>(), "FloatLatitude is not a valid alias");
|
static_assert(std::is_pod<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<FloatLongitude>(), "FloatLongitude is not a valid alias");
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Converts a typed latitude from floating to fixed representation.
|
* Converts a typed latitude from floating to fixed representation.
|
||||||
|
@ -47,9 +47,9 @@ struct osm_way_id
|
|||||||
};
|
};
|
||||||
}
|
}
|
||||||
using OSMNodeID = osrm::Alias<std::uint64_t, tag::osm_node_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>;
|
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 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()};
|
static const OSMWayID SPECIAL_OSM_WAYID = OSMWayID{std::numeric_limits<std::uint32_t>::max()};
|
||||||
|
@ -4,11 +4,11 @@
|
|||||||
#include "util/timing_util.hpp"
|
#include "util/timing_util.hpp"
|
||||||
|
|
||||||
#include <algorithm>
|
#include <algorithm>
|
||||||
|
#include <iomanip>
|
||||||
#include <numeric>
|
#include <numeric>
|
||||||
#include <random>
|
#include <random>
|
||||||
#include <string>
|
#include <string>
|
||||||
#include <vector>
|
#include <vector>
|
||||||
#include <iomanip>
|
|
||||||
|
|
||||||
using namespace osrm;
|
using namespace osrm;
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user