Better handling of printing results board
This commit is contained in:
@@ -1,7 +1,41 @@
|
||||
#pragma once
|
||||
#include <array>
|
||||
#include <chrono>
|
||||
#include <string>
|
||||
#include <stdint.h>
|
||||
|
||||
template<size_t N>
|
||||
constexpr void formatted_row(const std::array<int32_t, N>& gaps, const std::array<const char* const, N>& titles,
|
||||
const char* const separator = "│") noexcept {
|
||||
for(size_t i = 0; i < N; ++i)
|
||||
printf("%s %*s ", separator, -gaps[i], titles[i]);
|
||||
printf("%s\n", separator);
|
||||
}
|
||||
|
||||
template<size_t N>
|
||||
constexpr void formatted_line(const std::array<int32_t, N>& gaps, const char* const right, const char* const middle,
|
||||
const char* const separator, const char* const left) noexcept {
|
||||
printf("%s", right);
|
||||
for(size_t i = 0; i < N; ++i){
|
||||
for(int32_t j = std::abs(gaps[i]) + 2; j > 0; --j)
|
||||
printf("%s", separator);
|
||||
if(i != N - 1)
|
||||
printf("%s", middle);
|
||||
}
|
||||
|
||||
printf("%s\n", left);
|
||||
}
|
||||
|
||||
template<size_t N>
|
||||
constexpr void header(const std::array<const char* const, N>& titles, const std::array<int32_t, N>& gaps) noexcept {
|
||||
formatted_line(gaps, "┌", "┬", "─", "┐");
|
||||
formatted_row(gaps, titles);
|
||||
formatted_line(gaps, "├", "┼", "─", "┤");
|
||||
}
|
||||
|
||||
template<size_t N>
|
||||
constexpr inline void footer(const std::array<int32_t, N>& gaps) noexcept {
|
||||
formatted_line(gaps, "└", "┴", "─", "┘");
|
||||
}
|
||||
|
||||
#define duration_ns(a) std::chrono::duration_cast<std::chrono::nanoseconds>(a).count()
|
||||
#define perf_counter_ns() std::chrono::high_resolution_clock::now()
|
||||
|
Reference in New Issue
Block a user