Option to trim zeros at the end, more tests

This commit is contained in:
Vladyslav Baranovskyi
2024-09-20 12:44:01 +03:00
parent 350df1dc2f
commit c01155d8e4
3 changed files with 81 additions and 19 deletions

View File

@@ -11,36 +11,61 @@
namespace namespace
{ {
template<typename T> static std::string formatValue(T value, int precision) template<typename T> std::string FormatValue(T value, int precision, bool trimTrailingZeros = false)
{ {
std::ostringstream stream; std::ostringstream out;
stream << std::fixed << std::setprecision(precision) << value; out << std::fixed << std::setprecision(precision) << value;
return stream.str(); std::string result = out.str();
if (trimTrailingZeros && result.find('.') != std::string::npos)
{
result.erase(result.find_last_not_of('0') + 1);
if (result.back() == '.')
{
result.pop_back();
}
}
return result;
} }
} }
namespace OpenVulkano namespace OpenVulkano
{ {
UnitFormatter::UnitFormatter(bool useMetric, int precisionDigits) : metric(useMetric), precision(precisionDigits) {} UnitFormatter::UnitFormatter(bool useMetric, int precisionDigits, bool doTrimTrailingZeros)
: metric(useMetric), precision(precisionDigits), trimTrailingZeros(doTrimTrailingZeros)
{
}
std::string UnitFormatter::Format(units::length::meter_t distance) std::string UnitFormatter::Format(units::length::meter_t distance)
{ {
if (metric) if (metric)
{ {
if (distance >= units::length::kilometer_t(1)) if (distance > units::length::meter_t(0) && distance < units::length::meter_t(0.1))
{ {
return formatValue(units::length::kilometer_t(distance).value(), precision) + " km"; return FormatValue(units::length::millimeter_t(distance).value(), precision, trimTrailingZeros) + " mm";
} }
return formatValue(distance.value(), precision) + " m"; else if (distance >= units::length::kilometer_t(1))
{
return FormatValue(units::length::kilometer_t(distance).value(), precision, trimTrailingZeros) + " km";
}
return FormatValue(distance.value(), precision, trimTrailingZeros) + " m";
} }
else else
{ {
auto distanceFeet = units::length::foot_t(distance).value(); auto distanceFeet = units::length::foot_t(distance).value();
if (distanceFeet >= 5280.0) auto distanceInches = units::length::inch_t(distance).value();
if (distanceFeet > 0 && distanceFeet < 0.1)
{ {
return formatValue(units::length::mile_t(distance).value(), precision) + " mi"; return FormatValue(distanceInches, precision, trimTrailingZeros) + " in";
} }
return formatValue(distanceFeet, precision) + " ft"; else if (distanceFeet >= 5280.0)
{
return FormatValue(units::length::mile_t(distance).value(), precision, trimTrailingZeros) + " mi";
}
return FormatValue(distanceFeet, precision, trimTrailingZeros) + " ft";
} }
} }
@@ -50,18 +75,19 @@ namespace OpenVulkano
{ {
if (area >= units::area::square_kilometer_t(1)) if (area >= units::area::square_kilometer_t(1))
{ {
return formatValue(units::area::square_kilometer_t(area).value(), precision) + " km²"; return FormatValue(units::area::square_kilometer_t(area).value(), precision, trimTrailingZeros)
+ " km²";
} }
return formatValue(area.value(), precision) + ""; return FormatValue(area.value(), precision, trimTrailingZeros) + "";
} }
else else
{ {
auto areaSquareFeet = units::area::square_foot_t(area).value(); auto areaSquareFeet = units::area::square_foot_t(area).value();
if (areaSquareFeet >= 27878400.0) if (areaSquareFeet >= 27878400.0)
{ {
return formatValue(units::area::square_mile_t(area).value(), precision) + " mi²"; return FormatValue(units::area::square_mile_t(area).value(), precision, trimTrailingZeros) + " mi²";
} }
return formatValue(areaSquareFeet, precision) + " ft²"; return FormatValue(areaSquareFeet, precision, trimTrailingZeros) + " ft²";
} }
} }
} }

View File

@@ -14,9 +14,10 @@ namespace OpenVulkano
{ {
bool metric = true; bool metric = true;
int precision = 3; int precision = 3;
bool trimTrailingZeros = true;
public: public:
UnitFormatter(bool useMetric = true, int precisionDigits = 3); UnitFormatter(bool useMetric = true, int precisionDigits = 3, bool doTrimTrailingZeros = true);
std::string Format(units::length::meter_t distance); std::string Format(units::length::meter_t distance);
std::string Format(units::area::square_meter_t area); std::string Format(units::area::square_meter_t area);
}; };

View File

@@ -10,14 +10,16 @@
using namespace units::literals; using namespace units::literals;
TEST_CASE("testUnitFormatter", "[UnitFormatter]") TEST_CASE("testUnitFormatterWithTrailingZeros", "[UnitFormatter]")
{ {
OpenVulkano::UnitFormatter metricFormatter(true, 2); OpenVulkano::UnitFormatter metricFormatter(true, 2, false);
OpenVulkano::UnitFormatter imperialFormatter(false, 2); OpenVulkano::UnitFormatter imperialFormatter(false, 2, false);
units::length::meter_t positiveDistance = 1500.0_m; units::length::meter_t positiveDistance = 1500.0_m;
units::length::meter_t smallDistance = 0.5_m; units::length::meter_t smallDistance = 0.5_m;
units::length::meter_t negativeDistance = -100.0_m; units::length::meter_t negativeDistance = -100.0_m;
units::length::meter_t smallDistanceMetric = 0.05_m;
units::length::meter_t smallDistanceImperial = 0.03_m;
units::area::square_meter_t smallArea(0.005); units::area::square_meter_t smallArea(0.005);
units::area::square_meter_t negativeArea(-50.0); units::area::square_meter_t negativeArea(-50.0);
@@ -30,4 +32,37 @@ TEST_CASE("testUnitFormatter", "[UnitFormatter]")
REQUIRE(imperialFormatter.Format(negativeDistance) == "-328.08 ft"); REQUIRE(imperialFormatter.Format(negativeDistance) == "-328.08 ft");
REQUIRE(imperialFormatter.Format(smallArea) == "0.05 ft²"); REQUIRE(imperialFormatter.Format(smallArea) == "0.05 ft²");
REQUIRE(imperialFormatter.Format(negativeArea) == "-538.20 ft²"); REQUIRE(imperialFormatter.Format(negativeArea) == "-538.20 ft²");
REQUIRE(metricFormatter.Format(smallDistanceMetric) == "50.00 mm");
REQUIRE(imperialFormatter.Format(smallDistanceImperial) == "1.18 in");
} }
TEST_CASE("testUnitFormatterWithoutTrailingZeros", "[UnitFormatter]")
{
OpenVulkano::UnitFormatter metricFormatter(true, 2);
OpenVulkano::UnitFormatter imperialFormatter(false, 2);
units::length::meter_t positiveDistance = 1500.0_m;
units::length::meter_t smallDistance = 0.5_m;
units::length::meter_t negativeDistance = -100.0_m;
units::length::meter_t smallDistanceMetric = 0.05_m;
units::length::meter_t smallDistanceImperial = 0.03_m;
units::length::meter_t mediumDistanceMetric = 0.5_m;
units::length::meter_t largeDistanceMetric = 100.0_m;
units::area::square_meter_t smallArea(0.005);
units::area::square_meter_t negativeArea(-50.0);
REQUIRE(metricFormatter.Format(positiveDistance) == "1.5 km");
REQUIRE(metricFormatter.Format(smallDistance) == "0.5 m");
REQUIRE(metricFormatter.Format(negativeDistance) == "-100 m");
REQUIRE(metricFormatter.Format(smallArea) == "0.01 m²");
REQUIRE(metricFormatter.Format(negativeArea) == "-50 m²");
REQUIRE(imperialFormatter.Format(smallDistance) == "1.64 ft");
REQUIRE(imperialFormatter.Format(negativeDistance) == "-328.08 ft");
REQUIRE(imperialFormatter.Format(smallArea) == "0.05 ft²");
REQUIRE(imperialFormatter.Format(negativeArea) == "-538.2 ft²");
REQUIRE(metricFormatter.Format(smallDistanceMetric) == "50 mm");
REQUIRE(imperialFormatter.Format(smallDistanceImperial) == "1.18 in");
REQUIRE(metricFormatter.Format(smallDistanceMetric) == "50 mm");
REQUIRE(metricFormatter.Format(mediumDistanceMetric) == "0.5 m");
REQUIRE(metricFormatter.Format(largeDistanceMetric) == "100 m");
}