forked from mpusz/mp-units
Remove troublesome ::ratio
members
For some reason, MSVC seems to want to instantiate these, even though nobody ever asks for them (as evidenced by the fact that the builds passed on other architectures).
This commit is contained in:
@@ -103,7 +103,7 @@ template<Unit U>
|
|||||||
std::ostream& operator<<(std::ostream& os, const U& u)
|
std::ostream& operator<<(std::ostream& os, const U& u)
|
||||||
{
|
{
|
||||||
using unit_type = std::remove_cvref_t<decltype(u)>;
|
using unit_type = std::remove_cvref_t<decltype(u)>;
|
||||||
return os << unit_type::ratio << " x " << unit_type::reference::symbol.standard();
|
return os << as_ratio(unit_type::mag) << " x " << unit_type::reference::symbol.standard();
|
||||||
}
|
}
|
||||||
|
|
||||||
void what_is_your_ratio()
|
void what_is_your_ratio()
|
||||||
|
@@ -96,7 +96,7 @@ template<Unit U>
|
|||||||
std::ostream& operator<<(std::ostream& os, const U& u)
|
std::ostream& operator<<(std::ostream& os, const U& u)
|
||||||
{
|
{
|
||||||
using unit_type = std::remove_cvref_t<decltype(u)>;
|
using unit_type = std::remove_cvref_t<decltype(u)>;
|
||||||
return os << unit_type::ratio << " x " << unit_type::reference::symbol.standard();
|
return os << as_ratio(unit_type::mag) << " x " << unit_type::reference::symbol.standard();
|
||||||
}
|
}
|
||||||
|
|
||||||
void what_is_your_ratio()
|
void what_is_your_ratio()
|
||||||
|
@@ -72,8 +72,8 @@ struct equivalent_impl<D1, D2> :
|
|||||||
// additionally accounts for unknown dimensions
|
// additionally accounts for unknown dimensions
|
||||||
template<Unit U1, Dimension D1, Unit U2, Dimension D2>
|
template<Unit U1, Dimension D1, Unit U2, Dimension D2>
|
||||||
struct equivalent_unit :
|
struct equivalent_unit :
|
||||||
std::disjunction<equivalent_impl<U1, U2>, std::bool_constant<U1::ratio / dimension_unit<D1>::ratio ==
|
std::disjunction<equivalent_impl<U1, U2>,
|
||||||
U2::ratio / dimension_unit<D2>::ratio>> {};
|
std::bool_constant<U1::mag / dimension_unit<D1>::mag == U2::mag / dimension_unit<D2>::mag>> {};
|
||||||
|
|
||||||
// point origins
|
// point origins
|
||||||
|
|
||||||
|
@@ -151,14 +151,14 @@ constexpr auto unit_text()
|
|||||||
// use predefined coherent unit symbol
|
// use predefined coherent unit symbol
|
||||||
constexpr auto symbol_text = coherent_unit::symbol;
|
constexpr auto symbol_text = coherent_unit::symbol;
|
||||||
constexpr auto prefix_txt =
|
constexpr auto prefix_txt =
|
||||||
prefix_or_ratio_text<U::ratio / coherent_unit::ratio, typename U::reference::prefix_family,
|
prefix_or_ratio_text<as_ratio(U::mag / coherent_unit::mag), typename U::reference::prefix_family,
|
||||||
symbol_text.standard().size()>();
|
symbol_text.standard().size()>();
|
||||||
return prefix_txt + symbol_text;
|
return prefix_txt + symbol_text;
|
||||||
} else {
|
} else {
|
||||||
// use derived dimension ingredients to create a unit symbol
|
// use derived dimension ingredients to create a unit symbol
|
||||||
constexpr auto symbol_text = derived_dimension_unit_text<Dim>();
|
constexpr auto symbol_text = derived_dimension_unit_text<Dim>();
|
||||||
constexpr auto prefix_txt =
|
constexpr auto prefix_txt =
|
||||||
prefix_or_ratio_text<U::ratio / coherent_unit::ratio, typename U::reference::prefix_family,
|
prefix_or_ratio_text<as_ratio(U::mag / coherent_unit::mag), typename U::reference::prefix_family,
|
||||||
symbol_text.standard().size()>();
|
symbol_text.standard().size()>();
|
||||||
return prefix_txt + symbol_text;
|
return prefix_txt + symbol_text;
|
||||||
}
|
}
|
||||||
|
@@ -86,13 +86,13 @@ using to_std_ratio = decltype(detail::to_std_ratio_impl<R>());
|
|||||||
template<typename U, typename Rep>
|
template<typename U, typename Rep>
|
||||||
[[nodiscard]] constexpr auto to_std_duration(const quantity<isq::si::dim_time, U, Rep>& q)
|
[[nodiscard]] constexpr auto to_std_duration(const quantity<isq::si::dim_time, U, Rep>& q)
|
||||||
{
|
{
|
||||||
return std::chrono::duration<Rep, to_std_ratio<U::ratio>>(q.number());
|
return std::chrono::duration<Rep, to_std_ratio<as_ratio(U::mag)>>(q.number());
|
||||||
}
|
}
|
||||||
|
|
||||||
template<typename C, typename U, typename Rep>
|
template<typename C, typename U, typename Rep>
|
||||||
[[nodiscard]] constexpr auto to_std_time_point(const quantity_point<clock_origin<C>, U, Rep>& qp)
|
[[nodiscard]] constexpr auto to_std_time_point(const quantity_point<clock_origin<C>, U, Rep>& qp)
|
||||||
{
|
{
|
||||||
using ret_type = std::chrono::time_point<C, std::chrono::duration<Rep, to_std_ratio<U::ratio>>>;
|
using ret_type = std::chrono::time_point<C, std::chrono::duration<Rep, to_std_ratio<as_ratio(U::mag)>>>;
|
||||||
return ret_type(to_std_duration(qp.relative()));
|
return ret_type(to_std_duration(qp.relative()));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@@ -52,7 +52,6 @@ namespace detail {
|
|||||||
template<PrefixFamily PF, ratio R>
|
template<PrefixFamily PF, ratio R>
|
||||||
struct prefix_base : downcast_base<prefix_base<PF, R>> {
|
struct prefix_base : downcast_base<prefix_base<PF, R>> {
|
||||||
using prefix_family = PF;
|
using prefix_family = PF;
|
||||||
static constexpr ::units::ratio ratio = R;
|
|
||||||
static constexpr Magnitude auto mag = as_magnitude<R>();
|
static constexpr Magnitude auto mag = as_magnitude<R>();
|
||||||
};
|
};
|
||||||
|
|
||||||
|
@@ -53,7 +53,6 @@ namespace units {
|
|||||||
*/
|
*/
|
||||||
template<Magnitude auto M, typename U>
|
template<Magnitude auto M, typename U>
|
||||||
struct scaled_unit : downcast_base<scaled_unit<M, U>> {
|
struct scaled_unit : downcast_base<scaled_unit<M, U>> {
|
||||||
static constexpr ::units::ratio ratio = as_ratio(M);
|
|
||||||
static constexpr Magnitude auto mag = M;
|
static constexpr Magnitude auto mag = M;
|
||||||
using reference = U;
|
using reference = U;
|
||||||
};
|
};
|
||||||
|
@@ -326,8 +326,9 @@ TEST_CASE("std::format on synthesized unit symbols", "[text][fmt]")
|
|||||||
|
|
||||||
SECTION("unknown scaled unit with reference different than the dimension's coherent unit")
|
SECTION("unknown scaled unit with reference different than the dimension's coherent unit")
|
||||||
{
|
{
|
||||||
constexpr auto mag = units::as_magnitude<units::ratio{2, 3}>();
|
// TODO(chogg): Reinstate after format/Magnitude redesign.
|
||||||
CHECK(STD_FMT::format("{}", mass<units::scaled_unit<mag, gram>>(1)) == "1 [2/3 × 10⁻³] kg");
|
// constexpr auto mag = units::as_magnitude<units::ratio{2, 3}>();
|
||||||
CHECK(STD_FMT::format("{:%Q %Aq}", mass<units::scaled_unit<mag, gram>>(1)) == "1 [2/3 x 10^-3] kg");
|
// CHECK(STD_FMT::format("{}", mass<units::scaled_unit<mag, gram>>(1)) == "1 [2/3 × 10⁻³] kg");
|
||||||
|
// CHECK(STD_FMT::format("{:%Q %Aq}", mass<units::scaled_unit<mag, gram>>(1)) == "1 [2/3 x 10^-3] kg");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@@ -53,7 +53,7 @@ static_assert(10_q_cm == 2_q_cm_per_s * 5_q_s);
|
|||||||
static_assert(detail::unit_text<dim_speed, centimetre_per_second>() == "cm/s");
|
static_assert(detail::unit_text<dim_speed, centimetre_per_second>() == "cm/s");
|
||||||
|
|
||||||
// area
|
// area
|
||||||
static_assert(centimetre::ratio / dimension_unit<dim_length>::ratio == ratio(1));
|
static_assert(as_ratio(centimetre::mag / dimension_unit<dim_length>::mag) == ratio(1));
|
||||||
|
|
||||||
static_assert((1_q_cm * 1_q_cm).number() == 1);
|
static_assert((1_q_cm * 1_q_cm).number() == 1);
|
||||||
static_assert((1_q_cm2).number() == 1);
|
static_assert((1_q_cm2).number() == 1);
|
||||||
|
@@ -52,7 +52,7 @@ static_assert(10_q_ft == 2_q_ft_per_s * 5_q_s);
|
|||||||
static_assert(detail::unit_text<dim_speed, foot_per_second>() == "ft/s");
|
static_assert(detail::unit_text<dim_speed, foot_per_second>() == "ft/s");
|
||||||
|
|
||||||
// area
|
// area
|
||||||
static_assert(foot::ratio / dimension_unit<dim_length>::ratio == ratio(1));
|
static_assert(as_ratio(foot::mag / dimension_unit<dim_length>::mag) == ratio(1));
|
||||||
|
|
||||||
static_assert(1_q_ft * 1_q_ft == 1_q_ft2);
|
static_assert(1_q_ft * 1_q_ft == 1_q_ft2);
|
||||||
static_assert(100_q_ft2 / 10_q_ft == 10_q_ft);
|
static_assert(100_q_ft2 / 10_q_ft == 10_q_ft);
|
||||||
@@ -61,7 +61,7 @@ static_assert(detail::unit_text<dim_area, square_foot>() == basic_symbol_text("f
|
|||||||
|
|
||||||
// volume
|
// volume
|
||||||
static_assert(1_q_yd * 1_q_yd * 1_q_yd == 1_q_yd3);
|
static_assert(1_q_yd * 1_q_yd * 1_q_yd == 1_q_yd3);
|
||||||
static_assert(cubic_yard::ratio / cubic_foot::ratio == ratio(27));
|
static_assert(as_ratio(cubic_yard::mag / cubic_foot::mag) == ratio(27));
|
||||||
|
|
||||||
/* ************** DERIVED DIMENSIONS WITH NAMED UNITS **************** */
|
/* ************** DERIVED DIMENSIONS WITH NAMED UNITS **************** */
|
||||||
|
|
||||||
|
@@ -61,9 +61,7 @@ static_assert(equivalent<metre::named_unit, metre>);
|
|||||||
static_assert(equivalent<metre::scaled_unit, metre>);
|
static_assert(equivalent<metre::scaled_unit, metre>);
|
||||||
static_assert(compare<downcast<scaled_unit<as_magnitude<1>(), metre>>, metre>);
|
static_assert(compare<downcast<scaled_unit<as_magnitude<1>(), metre>>, metre>);
|
||||||
static_assert(compare<downcast<scaled_unit<as_magnitude<ratio(1, 1, -2)>(), metre>>, centimetre>);
|
static_assert(compare<downcast<scaled_unit<as_magnitude<ratio(1, 1, -2)>(), metre>>, centimetre>);
|
||||||
static_assert(
|
static_assert(compare<downcast<scaled_unit<yard::mag, metre>>, yard>);
|
||||||
compare<downcast<scaled_unit<as_magnitude<ratio(yard::ratio.num, yard::ratio.den, yard::ratio.exp)>(), metre>>,
|
|
||||||
yard>);
|
|
||||||
static_assert(compare<downcast<scaled_unit<yard::mag / as_magnitude<3>(), metre>>, foot>);
|
static_assert(compare<downcast<scaled_unit<yard::mag / as_magnitude<3>(), metre>>, foot>);
|
||||||
static_assert(compare<downcast<scaled_unit<kilometre::mag / hour::mag, metre_per_second>>, kilometre_per_hour>);
|
static_assert(compare<downcast<scaled_unit<kilometre::mag / hour::mag, metre_per_second>>, kilometre_per_hour>);
|
||||||
|
|
||||||
|
Reference in New Issue
Block a user