tap: use fmtlib specifiers

This commit is contained in:
Danny Robson 2021-04-13 16:05:08 +10:00
parent 4848178cc7
commit a94cd677bd
53 changed files with 137 additions and 130 deletions

11
tap.hpp
View File

@ -9,8 +9,10 @@
#pragma once
#include "except.hpp"
#include "format.hpp"
#include "maths.hpp"
#include "debug/validate.hpp"
#include <fmt/ostream.h>
#include <iosfwd>
#include <functional>
@ -50,10 +52,11 @@ namespace cruft::TAP {
bool
expect (const bool test, const char (&fmt)[N], Args&&... args)
{
CHECK (!strstr (fmt, "%"));
m_output << (test ? "ok " : "not ok ") << ++m_size
<< " - "
<< format::printf (fmt) (std::forward<Args> (args)...)
<< std::endl;
<< " - ";
fmt::print (m_output, fmt, std::forward<Args> (args)...);
m_output << std::endl;
if (!test)
m_status = EXIT_FAILURE;

View File

@ -138,7 +138,7 @@ test_perspective (cruft::TAP::logger &tap)
tap.expect (
cruft::relatively_equal (m, p, 1e-7f),
"perspective %!:%!@%!",
"perspective {}:{}@{}",
t.w, t.h, t.fov
);
}
@ -163,7 +163,7 @@ test_mq_axis (cruft::TAP::logger &tap)
auto q = cruft::quaternionf::angle_axis (1, t.euler);
auto diff = sum (abs (m - q.as_matrix ()));
tap.expect_le (diff, 1e-6f, "matrix/quaternion rotation identities, %s", t.msg);
tap.expect_le (diff, 1e-6f, "matrix/quaternion rotation identities, {:s}", t.msg);
}
}
@ -197,7 +197,7 @@ test_mq_euler (cruft::TAP::logger &tap)
).as_matrix ();
auto diff = cruft::sum (abs (m - q));
tap.expect_le (diff, 1e-6f, "matrix-quaternion xyz euler rotations, %s", t.msg);
tap.expect_le (diff, 1e-6f, "matrix-quaternion xyz euler rotations, {:s}", t.msg);
}
}

View File

@ -89,7 +89,7 @@ main (int, char**)
[] (int a, int b) { return a < b; }
);
tap.expect (std::is_sorted (std::cbegin (t.values), std::cend (t.values)), "%s", t.msg);
tap.expect (std::is_sorted (std::cbegin (t.values), std::cend (t.values)), "{:s}", t.msg);
}
// Check that SOA sort works with multiple value arrays

View File

@ -41,7 +41,7 @@ main (int, char**)
!(result[2] % alignment) &&
!(result[3] % alignment),
"allocations make alignment of %zu", alignment
"allocations make alignment of {}", alignment
);
return tap.status ();

View File

@ -47,7 +47,7 @@ main ()
for (const auto &t: TESTS) {
auto ptr = reinterpret_cast<uintptr_t> (alloc.allocate (t.size).data ());
auto offset = ptr - reinterpret_cast<uintptr_t> (base);
tap.expect_mod (offset, alignment, "%s", t.message);
tap.expect_mod (offset, alignment, "{:s}", t.message);
}
return tap.status ();

View File

@ -62,7 +62,7 @@ main (int, char**)
tap.expect (
is_digit && is_hex && is_upper && is_lower && is_space && integer && hexadecimal,
"%s", t.msg
"{:s}", t.msg
);
}

View File

@ -85,13 +85,13 @@ test_bool (cruft::TAP::logger &tap)
for (auto i: positive) {
argv[2] = i;
p.scan (argv.size (), argv.data ());
tap.expect_eq (value, true, "read bool, %s", i);
tap.expect_eq (value, true, "read bool, {:s}", i);
}
for (auto i: negative) {
argv[2] = i;
p.scan (argv.size (), argv.data ());
tap.expect_eq (value, false, "read bool, %s", i);
tap.expect_eq (value, false, "read bool, {:s}", i);
}
// Check that invalid forms of boolean all throw exceptions
@ -101,7 +101,7 @@ test_bool (cruft::TAP::logger &tap)
argv[2] = i;
tap.expect_throw<cruft::cmdopt::invalid_value> ([&] () {
p.scan (argv.size (), argv.data ());
}, "invalid bool, %s", i);
}, "invalid bool, {:s}", i);
}
}
@ -187,7 +187,7 @@ test_bytes (cruft::TAP::logger &tap)
argv[2] = i.str;
p.scan (std::size (argv), argv);
tap.expect_eq (i.val, size, "bytes, %s", i.str);
tap.expect_eq (i.val, size, "bytes, {:s}", i.str);
};
}

View File

@ -143,7 +143,7 @@ main (void)
};
for (auto const &t: TESTS)
tap.expect (cruft::coord::element_ordering (t.a, t.b) == t.expected, "ordering; %!", t.message);
tap.expect (cruft::coord::element_ordering (t.a, t.b) == t.expected, "ordering; {}", t.message);
}
return tap.status ();

View File

@ -84,7 +84,7 @@ test_size (cruft::TAP::logger &tap)
tap.expect_eq (
encoded,
output_v<Size>[i],
"%! character base%! encode; '%!' is '%!'", i, Size, encoded, output_v<Size>[i]
"{} character base{} encode; '{}' is '{}'", i, Size, encoded, output_v<Size>[i]
);
@ -94,7 +94,7 @@ test_size (cruft::TAP::logger &tap)
cruft::make_view (encoded)
);
tap.expect_eq (decoded, fragment, "%! character base%! decode, '%!'", i, Size, decoded);
tap.expect_eq (decoded, fragment, "{} character base{} decode, '{}'", i, Size, decoded);
}
}

View File

@ -1,6 +1,8 @@
#include "encode/number.hpp"
#include "tap.hpp"
#include <sstream>
int main ()
{
@ -22,7 +24,7 @@ int main ()
for (auto const &t: TESTS) {
// decode the truth string and test against the truth number
cruft::view src (t.str);
tap.expect_eq (cruft::encode::decode36<unsigned> (src), t.value, "base36 decode '%!'", t.str);
tap.expect_eq (cruft::encode::decode36<unsigned> (src), t.value, "base36 decode '{}'", t.str);
// encode the truth number
std::ostringstream dst;
@ -35,7 +37,7 @@ int main ()
std::transform (encoded_truth.begin (), encoded_truth.end (), encoded_truth.begin (), ::tolower);
// compare lower case encoded strings
tap.expect_eq (encoded_computed, encoded_truth, "base36 encode '%!'", t.value);
tap.expect_eq (encoded_computed, encoded_truth, "base36 encode '{}'", t.value);
}
return tap.status ();

View File

@ -22,7 +22,7 @@ main (int, char **argv)
tap.expect_eq (
query.stem (),
truth.stem (),
"identify executable path # %!", query
"identify executable path # {}", query
);
return tap.status ();

View File

@ -20,19 +20,19 @@ test_simple (cruft::TAP::logger &tap)
std::ostringstream os;
os << "fixed<" << type_to_string<T> () << ',' << I << ',' << E << '>';
tap.expect_eq (lo, lo, "%s self equality", os.str ());
tap.expect_eq (hi, hi, "%s self equality", os.str ());
tap.expect_eq (lo, lo, "{:s} self equality", os.str ());
tap.expect_eq (hi, hi, "{:s} self equality", os.str ());
tap.expect_neq (hi, lo, "%s inequality", os.str ());
tap.expect_neq (lo, hi, "%s inequality", os.str ());
tap.expect_neq (hi, lo, "{:s} inequality", os.str ());
tap.expect_neq (lo, hi, "{:s} inequality", os.str ());
tap.expect_lt (lo, hi, "%s less than", os.str ());
tap.expect_le (lo, hi, "%s less than equal", os.str ());
tap.expect_le (lo, lo, "%s less than equal", os.str ());
tap.expect_lt (lo, hi, "{:s} less than", os.str ());
tap.expect_le (lo, hi, "{:s} less than equal", os.str ());
tap.expect_le (lo, lo, "{:s} less than equal", os.str ());
tap.expect_gt (hi, lo, "%s greater than", os.str ());
tap.expect_ge (lo, lo, "%s greater than equal", os.str ());
tap.expect_ge (hi, lo, "%s greater than equal", os.str ());
tap.expect_gt (hi, lo, "{:s} greater than", os.str ());
tap.expect_ge (lo, lo, "{:s} greater than equal", os.str ());
tap.expect_ge (hi, lo, "{:s} greater than equal", os.str ());
}

View File

@ -21,7 +21,7 @@ main (void)
#define CHECK_RENDER(fmt,res,...) do { \
auto val = to_string (cruft::format::printf (fmt)(__VA_ARGS__)); \
tap.expect_eq (val, res, "render '%!', # %! == %!", fmt, val, res); \
tap.expect_eq (val, res, "render '{}', # {} == {}", fmt, val, res); \
} while (0)
CHECK_RENDER ("foo", "foo");
@ -182,7 +182,7 @@ main (void)
#define CHECK_THROW(fmt,except,...) do { \
tap.expect_throw<std::exception> ([&] { \
to_string (cruft::format::printf (fmt)(__VA_ARGS__)); \
}, "exception '%s' for format '%s'", #except, fmt); \
}, "exception '{:s}' for format '{:s}'", #except, fmt); \
} while (0)
CHECK_THROW("%", syntax_error);

View File

@ -48,7 +48,7 @@ main (int, char**)
for (auto const &t: TESTS) {
cruft::geom::aabb2f const shape (t.lo, t.hi);
cruft::geom::ray2f const r {t.base, t.direction};
tap.expect_eq (distance (r, shape), t.distance, "%!", t.message);
tap.expect_eq (distance (r, shape), t.distance, "{}", t.message);
}
};

View File

@ -39,7 +39,7 @@ test_intersection (cruft::TAP::logger &tap)
};
for (auto const& t: TESTS) {
tap.expect_eq (t.distance, distance (t.caster, t.shape), "%s", t.message);
tap.expect_eq (t.distance, distance (t.caster, t.shape), "{:s}", t.message);
}
}
@ -57,7 +57,7 @@ test_area (cruft::TAP::logger &tap)
for (auto const& t: TESTS) {
auto found = area (t.shape);
tap.expect (cruft::relatively_equal (found, t.value, 1.08e-2f), "%!", t.message);
tap.expect (cruft::relatively_equal (found, t.value, 1.08e-2f), "{}", t.message);
}
}
@ -105,7 +105,7 @@ test_cover (cruft::TAP::logger &tap)
return intersects (shape, p);
});
tap.expect (success, "%!", t.message);
tap.expect (success, "{}", t.message);
}
}

View File

@ -29,7 +29,7 @@ main ()
};
for (const auto &t: TESTS) {
tap.expect_eq (intersects (origin90, t.box), t.intersects, "origin frustrum, %s", t.message);
tap.expect_eq (intersects (origin90, t.box), t.intersects, "origin frustrum, {:s}", t.message);
}
return tap.status ();

View File

@ -21,7 +21,7 @@ main (int, char**)
for (auto const& t: TESTS) {
cruft::geom::line3f l { t.origin, t.direction };
auto d = distance2 (l, t.q);
tap.expect_eq (d, t.distance, "%!", t.message);
tap.expect_eq (d, t.distance, "{}", t.message);
}
return tap.status ();

View File

@ -20,7 +20,7 @@ test_distances (cruft::TAP::logger &tap)
for (auto const &t: TESTS) {
auto const p = cruft::geom::make_plane (t.a, t.b, t.c);
const auto d = distance (p, t.query);
tap.expect_eq (d, t.distance, "%!", t.message);
tap.expect_eq (d, t.distance, "{}", t.message);
}
};

View File

@ -26,7 +26,7 @@ int main ()
bool const y_perim = pos.y == 0 || pos.y == AREA.h;
if (!x_perim && !y_perim) {
tap.fail ("position %! falls outside perimeter: %!", i, pos);
tap.fail ("position {} falls outside perimeter: {}", i, pos);
return tap.status ();
}
@ -54,7 +54,7 @@ int main ()
tap.expect_lt (
std::abs (rel_diff), 0.05f,
"occurence counts are evenly spaced: %!:%! vs %!:%!",
"occurence counts are evenly spaced: {}:{} vs {}:{}",
hi->first, hi->second,
lo->first, lo->second
);

View File

@ -40,7 +40,7 @@ main ()
}
}
tap.expect (success, "subregion coverage validity, %!", msg);
tap.expect (success, "subregion coverage validity, {}", msg);
}
return tap.status ();

View File

@ -22,7 +22,7 @@ void test_point_distance (cruft::TAP::logger &tap)
for (auto const& t: TESTS) {
cruft::geom::segment3f s {t.a, t.b};
auto d = distance (s, t.q);
tap.expect_eq (d, t.distance, "%!", t.message);
tap.expect_eq (d, t.distance, "{}", t.message);
}
}
@ -65,7 +65,7 @@ void test_region_intersection (cruft::TAP::logger &tap)
};
for (auto const &t: TESTS)
tap.expect_eq (intersects (t.a, t.b), t.expected, "region intersection: %!", t.message);
tap.expect_eq (intersects (t.a, t.b), t.expected, "region intersection: {}", t.message);
}
@ -108,7 +108,7 @@ void test_bresenham (cruft::TAP::logger &tap)
std::vector<cruft::point2i> computed;
for (auto const p: cruft::geom::bresenham ({ t.a, t.b }))
computed.push_back (p);
tap.expect_eq (computed, t.expected, "bresenham: %!", t.message);
tap.expect_eq (computed, t.expected, "bresenham: {}", t.message);
}
}

View File

@ -45,7 +45,7 @@ test_intersect (cruft::TAP::logger &tap)
};
for (const auto &[d,s,r,msg]: TESTS) {
tap.expect_eq (d, distance (r, s), "%!", msg);
tap.expect_eq (d, distance (r, s), "{}", msg);
}
}

View File

@ -40,13 +40,13 @@ main (int, char**) {
tap.expect_eq (
t.adler,
a (cruft::view {t.data}.template cast<const uint8_t*> ()),
"adler checksum: %s", t.msg
"adler checksum: {:s}", t.msg
);
tap.expect_eq (
t.bsd,
b (cruft::view {t.data}.template cast<const uint8_t*> ()),
"bsdsum checksum: %s", t.msg);
"bsdsum checksum: {:s}", t.msg);
}
return tap.status ();

View File

@ -34,7 +34,7 @@ main (int, char**)
for (const auto &t: TESTS) {
#define TEST(KLASS) do { \
auto computed = cruft::hash::KLASS{}(cruft::view {t.dat}.template cast<const uint8_t*> ()); \
tap.expect_eq (t.result.KLASS, computed, "%s: %s", #KLASS, t.msg); \
tap.expect_eq (t.result.KLASS, computed, "{:s}: {:s}", #KLASS, t.msg); \
} while (0)
TEST(crc32);

View File

@ -47,8 +47,8 @@ main (void)
for (const auto &t: TESTS) {
cruft::view data { t.data };
tap.expect_eq (t.hash32, h32 (t.seed32, data.cast<uint8_t const*> ()), "h32(%0" PRIx32 ")", t.seed32);
tap.expect_eq (t.hash64, h64 (t.seed64, data.cast<uint8_t const*> ()), "h64(%0" PRIx64 ")", t.seed64);
tap.expect_eq (t.hash32, h32 (t.seed32, data.cast<uint8_t const*> ()), "h32({:#04x})", t.seed32);
tap.expect_eq (t.hash64, h64 (t.seed64, data.cast<uint8_t const*> ()), "h64({:#08x})", t.seed64);
}
tap.expect (success32, "fasthash32");

View File

@ -24,8 +24,8 @@ main (void)
const cruft::hash::fnv1a<uint64_t> h64;
for (const auto &t: TESTS) {
tap.expect_eq (h32 (cruft::view{t.data}.cast <const uint8_t*> ()), t.h32, "fnv1a32: '%s'", t.data);
tap.expect_eq (h64 (cruft::view{t.data}.cast <const uint8_t*> ()), t.h64, "fnv1a64: '%s'", t.data);
tap.expect_eq (h32 (cruft::view{t.data}.cast <const uint8_t*> ()), t.h32, "fnv1a32: '{:s}'", t.data);
tap.expect_eq (h64 (cruft::view{t.data}.cast <const uint8_t*> ()), t.h64, "fnv1a64: '{:s}'", t.data);
}
return tap.status ();

View File

@ -124,13 +124,13 @@ test (cruft::TAP::logger &tap)
const cruft::hash::murmur3_128_x86 h3_x86 (t.m3_128_x86.seed);
const cruft::hash::murmur3_128_x64 h3_x64 (t.m3_128_x64.seed);
tap.expect_eq (h1 (t.data), t.m1_32.hash, "murmur1_32, '%s'", t.msg);
tap.expect_eq (h2_32 (t.data), t.m2_32.hash, "murmur2_32, '%s'", t.msg);
tap.expect_eq (h2_64 (t.data), t.m2_64.hash, "murmur2_64, '%s'", t.msg);
tap.expect_eq (h1 (t.data), t.m1_32.hash, "murmur1_32, '{:s}'", t.msg);
tap.expect_eq (h2_32 (t.data), t.m2_32.hash, "murmur2_32, '{:s}'", t.msg);
tap.expect_eq (h2_64 (t.data), t.m2_64.hash, "murmur2_64, '{:s}'", t.msg);
tap.expect_eq (h3 (t.data), t.m3_32.hash, "murmur3_32, '%s'", t.msg);
tap.expect_eq (h3_x86 (t.data), t.m3_128_x86.hash, "murmur3_128_x86, '%s'", t.msg);
tap.expect_eq (h3_x64 (t.data), t.m3_128_x64.hash, "murmur3_128_x64, '%s'", t.msg);
tap.expect_eq (h3 (t.data), t.m3_32.hash, "murmur3_32, '{:s}'", t.msg);
tap.expect_eq (h3_x86 (t.data), t.m3_128_x86.hash, "murmur3_128_x86, '{:s}'", t.msg);
tap.expect_eq (h3_x64 (t.data), t.m3_128_x64.hash, "murmur3_128_x64, '{:s}'", t.msg);
}
}

View File

@ -30,7 +30,7 @@ main ()
for (const auto &t: TESTS) {
cruft::hash::siphash<2,4> h (t.key);
tap.expect_eq (h (t.data), t.digest, "%s", t.message);
tap.expect_eq (h (t.data), t.digest, "{:s}", t.message);
}
return tap.status ();

View File

@ -35,7 +35,7 @@ void test_type (cruft::TAP::logger &tap)
auto const pos = std::adjacent_find (std::begin (results), std::end (results));
tap.expect (
pos == std::end (results),
"no equal elements, %!",
"no equal elements, {}",
cruft::introspection::name::bare<ValueT> ()
);
}
@ -62,7 +62,7 @@ void test_type (cruft::TAP::logger &tap)
tap.expect (
success,
"equal counts at bit positions, %!",
"equal counts at bit positions, {}",
cruft::introspection::name::bare<ValueT> ()
);
}

View File

@ -52,8 +52,8 @@ main (int, char **)
cruft::hash::xxhash32 h32 (t.seed);
cruft::hash::xxhash64 h64 (t.seed);
tap.expect_eq (h32 (t.data), t.hash32, "xxhash32 %s", t.msg);
tap.expect_eq (h64 (t.data), t.hash64, "xxhash64 %s, seed %!", t.msg, t.seed);
tap.expect_eq (h32 (t.data), t.hash32, "xxhash32 {:s}", t.msg);
tap.expect_eq (h64 (t.data), t.hash64, "xxhash64 {:s}, seed {}", t.msg, t.seed);
}
return tap.status ();

View File

@ -2,6 +2,7 @@
#include "introspection/name.hpp"
#include "introspection/type.hpp"
#include "std.hpp"
#include "view.hpp"
#include "tap.hpp"
#include <iostream>

View File

@ -45,7 +45,7 @@ test_iota (cruft::TAP::logger &tap)
{
cruft::iterator::iota seq (5);
auto const sum = std::accumulate (std::begin (seq), std::end (seq), 0u);
tap.expect_eq (sum, 4u+3u+2u+1u+0u, "iota summation %!", sum);
tap.expect_eq (sum, 4u+3u+2u+1u+0u, "iota summation {}", sum);
}

View File

@ -45,6 +45,6 @@ main (void)
success = count == INNER && success;
}
tap.expect (success, "%! trivial increment jobs of size %!", OUTTER, INNER);
tap.expect (success, "{} trivial increment jobs of size {}", OUTTER, INNER);
return tap.status ();
}

View File

@ -135,8 +135,8 @@ test_normalisations (cruft::TAP::logger &tap)
};
for (const auto &t: TESTS) {
tap.expect_eq (cruft::renormalise<int32_t,uint32_t> (t.sint), t.uint, "%s s32-to-u32", t.msg);
tap.expect_eq (cruft::renormalise<uint32_t,int32_t> (t.uint), t.sint, "%s u32-to-s32", t.msg);
tap.expect_eq (cruft::renormalise<int32_t,uint32_t> (t.sint), t.uint, "{:s} s32-to-u32", t.msg);
tap.expect_eq (cruft::renormalise<uint32_t,int32_t> (t.uint), t.sint, "{:s} u32-to-s32", t.msg);
}
}
}

View File

@ -87,11 +87,11 @@ main ()
//
// const float relerr = 1 - observed / expected;
// std::cout << observed << '\t' << expected << '\t' << relerr << '\n';
// tap.expect_lt (relerr, 1e-4f, "relative exp(%!) error", i);
// tap.expect_lt (relerr, 1e-4f, "relative exp({}) error", i);
//}
tap.expect_eq (successes.sin, std::size (sins), "sin evaluation, %!/%!", successes.sin, std::size (sins));
tap.expect_eq (successes.exp, std::size (exps), "exp evaluation, %!/%!", successes.exp, std::size (exps));
tap.expect_eq (successes.sin, std::size (sins), "sin evaluation, {}/{}", successes.sin, std::size (sins));
tap.expect_eq (successes.exp, std::size (exps), "exp evaluation, {}/{}", successes.exp, std::size (exps));
return tap.status ();
}

View File

@ -214,7 +214,7 @@ main (void)
truth, euler,
[] (auto a, auto b) { return cruft::almost_equal (a, b); }
)),
"matrix-to-euler, %s",
"matrix-to-euler, {:s}",
t.msg
);
}

View File

@ -1,8 +1,9 @@
#include "tap.hpp"
#include "parallel/queue.hpp"
#include "thread/flag.hpp"
#include "thread/semaphore.hpp"
#include "tap.hpp"
#include "view.hpp"
#include <algorithm>

View File

@ -66,7 +66,7 @@ int main ()
for (auto &t: contestants)
t.join ();
tap.expect (true, "n-way fight, %! contestants", contestants.size ());
tap.expect (true, "n-way fight, {} contestants", contestants.size ());
}
return tap.status ();

View File

@ -25,7 +25,7 @@ int main ()
if (!res) {
tap.fail ("SI parsing %!", t.str);
} else {
tap.expect_eq (t.val, *res, "SI parsing '%!'", t.str);
tap.expect_eq (t.val, *res, "SI parsing '{}'", t.str);
}
}

View File

@ -37,7 +37,7 @@ int main ()
for (auto const &[str,val,msg]: TESTS) {
auto res = cruft::parse::duration::from (str);
tap.expect (res && val == *res, "%! %! == %!", msg, val.count (), res->count());
tap.expect (res && val == *res, "{} {} == {}", msg, val.count (), res->count());
}
return tap.status ();

View File

@ -51,7 +51,7 @@ main (int, char**)
ok = false;
}
tap.expect (ok, "%s", i.name);
tap.expect (ok, "{:s}", i.name);
}
return tap.status ();

View File

@ -89,7 +89,7 @@ main (void)
auto m = cruft::rotation<float> (r.mag, r.axis);
auto diff = cruft::abs (q - m);
tap.expect_lt (cruft::sum (diff), 1e-6f, "single basis rotation %zu", i);
tap.expect_lt (cruft::sum (diff), 1e-6f, "single basis rotation {:d}", i);
}
auto q = quaternionf::identity ();
@ -127,7 +127,7 @@ main (void)
auto v = rotate (src, q);
auto diff = std::abs (cruft::sum (dst - v));
tap.expect_lt (diff, 1e-06f, "quaternion from-to, %s", t.msg);
tap.expect_lt (diff, 1e-06f, "quaternion from-to, {:s}", t.msg);
}
}
@ -144,7 +144,7 @@ main (void)
tap.expect_eq (
cruft::quaternionf::from_euler ({ t.x, t.y, t.z }),
t.expected,
"from_euler: %!",
"from_euler: {}",
t.msg
);
}

View File

@ -40,7 +40,7 @@ test_buckets (cruft::TAP::logger &tap, Args&& ...args)
std::find_if (std::cbegin (buckets),
std::cend (buckets),
[] (auto v) { return v < EXPECTED * 7 / 8; }) == std::cend (buckets),
"bucket counts for %s", cruft::introspection::name::full<GeneratorT> ()
"bucket counts for {:s}", cruft::introspection::name::full<GeneratorT> ()
);
}

View File

@ -49,8 +49,8 @@ main (int, char **)
};
for (auto const &[a, b, res, msg]: TESTS) {
tap.expect_eq (a.intersects (b), res, "intersection a-on-b: %!", msg);
tap.expect_eq (b.intersects (a), res, "intersection b-on-a: %!", msg);
tap.expect_eq (a.intersects (b), res, "intersection a-on-b: {}", msg);
tap.expect_eq (b.intersects (a), res, "intersection b-on-a: {}", msg);
}
}
@ -131,7 +131,7 @@ main (int, char **)
};
for (auto const &[a, b, expected, msg]: TESTS)
tap.expect_eq (a.covers (b), expected, "covers: %!", msg);
tap.expect_eq (a.covers (b), expected, "covers: {}", msg);
}
// ensure make_region covers the expected values
@ -185,7 +185,7 @@ main (int, char **)
for (auto const &t: TESTS) {
auto const d2 = distance2 (t.r, t.p);
tap.expect_eq (d2, t.distance2, "region-point distance2: %!", t.message);
tap.expect_eq (d2, t.distance2, "region-point distance2: {}", t.message);
}
};
@ -233,7 +233,7 @@ main (int, char **)
};
for (auto const &[a, b, res, message]: TESTS)
tap.expect_eq (intersection (a, b), res, "region-region interesection: %!", message);
tap.expect_eq (intersection (a, b), res, "region-region interesection: {}", message);
}
// Test rotate behaves as expected.
@ -282,7 +282,7 @@ main (int, char **)
for (auto const &obj: TESTS) {
auto const computed = rotate90 (orig, obj.rotation);
tap.expect_eq (computed, obj.res, "%! rotation", obj.rotation);
tap.expect_eq (computed, obj.res, "{} rotation", obj.rotation);
}
}

View File

@ -33,7 +33,7 @@ main (void)
for (const auto &t: TESTS) {
constexpr float TOLERANCE = 0.00001f;
auto root = cruft::roots::bisection (t.lo, t.hi, t.func, TOLERANCE);
tap.expect_eq (root, t.root, "%s", t.msg);
tap.expect_eq (root, t.root, "{:s}", t.msg);
}
return tap.status ();

View File

@ -26,8 +26,8 @@ test_transforms (cruft::TAP::logger &tap)
};
for (auto const &[src, upper, lower, msg]: TESTS) {
tap.expect_eq (cruft::to_upper (src), upper, "to_upper, %!", msg);
tap.expect_eq (cruft::to_lower (src), lower, "to_lower, %!", msg);
tap.expect_eq (cruft::to_upper (src), upper, "to_upper, {:s}", msg);
tap.expect_eq (cruft::to_lower (src), lower, "to_lower, {:s}", msg);
}
}
@ -57,7 +57,7 @@ test_position (cruft::TAP::logger &tap)
tap.expect (
pos.line == t.line && pos.column == t.column,
"character_position %!:%!",
"character_position {}:{}",
t.line,
t.column
);
@ -90,7 +90,7 @@ test_tokeniser (cruft::TAP::logger &tap)
cruft::view src { csv.c_str (), csv.size () };
for (auto [tok, expected]: cruft::iterator::zip (cruft::tokeniser (src, ','), TESTS)) {
tap.expect (equal (tok, expected.value), "%s", expected.message);
tap.expect (equal (tok, expected.value), "{:s}", expected.message);
}
}
@ -164,7 +164,7 @@ test_contains (cruft::TAP::logger &tap)
for (auto const &t: TESTS) {
cruft::tokeniser tok (t.haystack, t.separator);
auto const found = tok.contains (t.needle);
tap.expect_eq (found, t.expected, "%!", t.message);
tap.expect_eq (found, t.expected, "{}", t.message);
}
}
@ -186,7 +186,7 @@ void test_comparator_less (cruft::TAP::logger &tap)
};
for (auto const &t: TESTS)
tap.expect_eq (cmp (t.a, t.b), t.less, "string_less, %!", t.message);
tap.expect_eq (cmp (t.a, t.b), t.less, "string_less, {}", t.message);
}
@ -209,7 +209,7 @@ void test_comparator_lower (cruft::TAP::logger &tap)
cruft::string::compare::lower cmp;
for (auto const &t: TESTS) {
tap.expect_eq (cmp (t.a, t.b), t.equal, "compare::lower, pointers, %!", t.message);
tap.expect_eq (cmp (t.a, t.b), t.equal, "compare::lower, pointers, {}", t.message);
}
}

View File

@ -53,7 +53,7 @@ main ()
for (auto &t: contestants)
t.join ();
tap.expect (true, "n-way fight, %! contestants", std::thread::hardware_concurrency ());
tap.expect (true, "n-way fight, {} contestants", std::thread::hardware_concurrency ());
}
return tap.status ();

View File

@ -16,7 +16,7 @@ main (int, char**)
for (const auto &t: BAD) {
tap.expect_throw<std::invalid_argument> (
[t] () { cruft::time::iso8601::parse (t); },
"invalid timestamp '%s'", t
"invalid timestamp '{:s}'", t
);
}
@ -39,7 +39,7 @@ main (int, char**)
for (const auto &t: DECODE) {
auto val = cruft::time::iso8601::parse (t.string);
tap.expect_eq (val, t.value, "%s", t.message);
tap.expect_eq (val, t.value, "{:s}", t.message);
}
tap.expect_eq (

View File

@ -140,18 +140,18 @@ main (void)
};
for (auto t: GOOD) {
tap.expect_nothrow ([t] (void) { cruft::uri foo (t.src); }, "nothrow parsing '%s'", t.src);
tap.expect_nothrow ([t] (void) { cruft::uri foo (t.src); }, "nothrow parsing '{:s}'", t.src);
cruft::uri u (t.src);
tap.expect_eq (u.scheme (), t.scheme, "scheme for '%s'", t.src);
tap.expect_eq (u.heirarchical (), t.hierarchical, "hierarchical for '%s'", t.src);
tap.expect_eq (u.authority (), t.authority, "authority for '%s'", t.src);
tap.expect_eq (u.host (), t.host, "host for '%s'", t.src);
tap.expect_eq (u.user (), t.user, "user for '%s'", t.src);
tap.expect_eq (u.port (), t.port, "port for '%s'", t.src);
tap.expect_eq (u.path (), t.path, "path for '%s'", t.src);
tap.expect_eq (u.query (), t.query, "query for '%s'", t.src);
tap.expect_eq (u.fragment (), t.fragment, "fragment for '%s'", t.src);
tap.expect_eq (u.scheme (), t.scheme, "scheme for '{:s}'", t.src);
tap.expect_eq (u.heirarchical (), t.hierarchical, "hierarchical for '{:s}'", t.src);
tap.expect_eq (u.authority (), t.authority, "authority for '{:s}'", t.src);
tap.expect_eq (u.host (), t.host, "host for '{:s}'", t.src);
tap.expect_eq (u.user (), t.user, "user for '{:s}'", t.src);
tap.expect_eq (u.port (), t.port, "port for '{:s}'", t.src);
tap.expect_eq (u.path (), t.path, "path for '{:s}'", t.src);
tap.expect_eq (u.query (), t.query, "query for '{:s}'", t.src);
tap.expect_eq (u.fragment (), t.fragment, "fragment for '{:s}'", t.src);
}
static const char* BAD[] = {
@ -160,7 +160,7 @@ main (void)
for (auto i: BAD)
tap.expect_throw<cruft::uri::parse_error> (
[i] (void) { cruft::uri foo (i); }, "throw parsing '%s'", i
[i] (void) { cruft::uri foo (i); }, "throw parsing '{:s}'", i
);

View File

@ -26,7 +26,7 @@ simple_valid (cruft::TAP::logger &tap)
#endif
};
static constexpr char fmt[] = "valid length, %s";
static constexpr char fmt[] = "valid length, {:s}";
for (const auto &t: VALID) {
try {
@ -71,7 +71,7 @@ single_boundaries (cruft::TAP::logger &tap)
{ { 0xF4, 0x90, 0x80, 0x80 }, 0x00110000, "other" },
};
static constexpr char fmt[] = "single character (%s), %!-byte sequence";
static constexpr char fmt[] = "single character ({:s}), {}-byte sequence";
for (const auto &t: TESTS) {
auto data = cruft::make_view (
@ -111,7 +111,7 @@ malformed (cruft::TAP::logger &tap)
{ { 0x80, 0xBF, 0x80, 0xBF }, "continuation sequence" },
};
static constexpr char fmt[] = "malformed %! byte sequence, %s";
static constexpr char fmt[] = "malformed {} byte sequence, {:s}";
for (const auto &t: TESTS) {
auto data = cruft::make_view (
@ -179,7 +179,7 @@ malformed (cruft::TAP::logger &tap)
{ success = false; }
}
tap.expect (success, "lonely start characters, %! bytes", t.length);
tap.expect (success, "lonely start characters, {} bytes", t.length);
}
@ -197,7 +197,7 @@ malformed (cruft::TAP::logger &tap)
tap.expect_throw<cruft::utf8::malformed_error> (
[&data] () { cruft::utf8::decode (data); },
"%! byte sequence missing the lastbyte",
"{} byte sequence missing the lastbyte",
t.size ()
);
}
@ -217,7 +217,7 @@ malformed (cruft::TAP::logger &tap)
tap.expect_throw<cruft::utf8::malformed_error> (
[&data] () { cruft::utf8::decode (data); },
"impossible %! byte sequence",
"impossible {} byte sequence",
t.size ()
);
}
@ -255,7 +255,7 @@ overlong (cruft::TAP::logger &tap)
[&] () {
cruft::utf8::decode (data);
},
"overlong %! byte sequence, %s",
"overlong {} byte sequence, {:s}",
t.data.size (),
t.message
);

View File

@ -51,7 +51,7 @@ test_polar (cruft::TAP::logger &tap)
auto in_cart = t.cartesian;
auto to_cart = cruft::polar_to_cartesian (t.polar);
tap.expect_lt (norm (in_cart - to_cart), 0.00001f, "%s", t.desc);
tap.expect_lt (norm (in_cart - to_cart), 0.00001f, "{:s}", t.desc);
// Compare polar representations. Make sure to normalise them first.
auto in_polar = t.polar;
@ -60,7 +60,7 @@ test_polar (cruft::TAP::logger &tap)
in_polar[1] = std::fmod (in_polar[1], 2 * cruft::pi<float>);
to_polar[1] = std::fmod (to_polar[1], 2 * cruft::pi<float>);
tap.expect_eq (in_polar, to_polar, "%s", t.desc);
tap.expect_eq (in_polar, to_polar, "{:s}", t.desc);
}
}
@ -89,7 +89,7 @@ test_euler (cruft::TAP::logger &tap)
for (auto i: TESTS) {
tap.expect_eq (cruft::to_euler (i.dir),
i.euler * cruft::pi<float>,
"to euler, %s", i.name);
"to euler, {:s}", i.name);
}
// check error in round trip through euler angles
@ -100,7 +100,7 @@ test_euler (cruft::TAP::logger &tap)
// trig functions reduce precision above almost_equal levels, so we
// hard code a fairly low bound here instead.
tap.expect_lt (mag, 1e-7, "euler round-trip error, %s", i.name);
tap.expect_lt (mag, 1e-7, "euler round-trip error, {:s}", i.name);
}
}
@ -135,7 +135,7 @@ test_spherical (cruft::TAP::logger &tap)
for (const auto t: S2C) {
tap.expect (
all (abs (cruft::spherical_to_cartesian (t.spherical) - t.cartesian) < 1e-7f),
"%s, spherical-cartesian",
"{:s}, spherical-cartesian",
t.message
);
}
@ -188,7 +188,7 @@ test_spherical (cruft::TAP::logger &tap)
const auto s1 = cruft::canonical_spherical (t.spherical);
tap.expect (
all (abs (s0 - s1) < 1e-4f),
"%s, cartesian-spherical",
"{:s}, cartesian-spherical",
t.message
);
}
@ -197,7 +197,7 @@ test_spherical (cruft::TAP::logger &tap)
//tap.expect_eq (
// cruft::cartesian_to_spherical (t.cartesian),
// t.spherical,
// "%s, cartesian-spherical",
// "{:s}, cartesian-spherical",
// t.message
//);

View File

@ -55,7 +55,7 @@ main () {
bool parts = std::equal (v.begin (), v.end (), t.parts);
bool release = v.release == t.release;
tap.expect (parts && release, "%s", t.msg);
tap.expect (parts && release, "{:s}", t.msg);
}
@ -64,9 +64,9 @@ main () {
const bool lt = t.a < t.b;
const bool gt = t.a > t.b;
tap.expect (t.eq == eq, "%s: equality", t.msg);
tap.expect (t.lt == lt, "%s: less-than", t.msg);
tap.expect (t.gt == gt, "%s: greater-than", t.msg);
tap.expect (t.eq == eq, "{:s}: equality", t.msg);
tap.expect (t.lt == lt, "{:s}: less-than", t.msg);
tap.expect (t.gt == gt, "{:s}: greater-than", t.msg);
}
return tap.status ();

View File

@ -73,7 +73,7 @@ main (int, char**)
};
for (const auto &t: TESTS) {
tap.expect_eq (cruft::view { t.init }.slice (t.a, t.b), t.result, "slice; %s", t.message);
tap.expect_eq (cruft::view { t.init }.slice (t.a, t.b), t.result, "slice; {:s}", t.message);
}
}