Compare commits
No commits in common. "master" and "feature/smaller_size" have entirely different histories.
master
...
feature/sm
@ -66,13 +66,16 @@ constexpr inline void format_arg(char* dest, const char* arg) {
|
|||||||
};
|
};
|
||||||
|
|
||||||
|
|
||||||
|
// End of recursion
|
||||||
|
template <auto ast>
|
||||||
|
constexpr inline void format_args(char*) {
|
||||||
|
}
|
||||||
|
|
||||||
template <auto fmt_data_array, typename first_arg_t, typename... args_t>
|
template <auto fmt_data_array, typename first_arg_t, typename... args_t>
|
||||||
constexpr inline void format_args(char* dest, first_arg_t first_arg,
|
constexpr inline void format_args(char* dest, first_arg_t first_arg,
|
||||||
args_t... args) {
|
args_t... args) {
|
||||||
format_arg<fmt_data_array[0]>(dest + fmt_data_array[0].position, first_arg);
|
format_arg<fmt_data_array[0]>(dest + fmt_data_array[0].position, first_arg);
|
||||||
|
format_args<drop_first(fmt_data_array)>(dest, args...);
|
||||||
if constexpr(fmt_data_array.size() > 1)
|
|
||||||
format_args<drop_first(fmt_data_array)>(dest, args...);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|||||||
@ -187,8 +187,7 @@ concept floating_point = is_floating_point_v<type_t>;
|
|||||||
|
|
||||||
|
|
||||||
template <typename input_t, typename output_t>
|
template <typename input_t, typename output_t>
|
||||||
constexpr inline void copy(const input_t* start, const input_t* end,
|
constexpr inline void copy(const input_t* start, const input_t* end, output_t* dest_start) {
|
||||||
output_t* dest_start) {
|
|
||||||
auto temp = start;
|
auto temp = start;
|
||||||
while (temp != end)
|
while (temp != end)
|
||||||
*(dest_start++) = *(temp++);
|
*(dest_start++) = *(temp++);
|
||||||
@ -237,9 +236,9 @@ public:
|
|||||||
static_assert(sizeof...(args) == t_size, "Invalid number of arguments");
|
static_assert(sizeof...(args) == t_size, "Invalid number of arguments");
|
||||||
}
|
}
|
||||||
|
|
||||||
constexpr array() noexcept = default;
|
constexpr array() noexcept = default;
|
||||||
constexpr array(const array&) = default;
|
constexpr array(const array&) = default;
|
||||||
constexpr array(array&&) = default;
|
constexpr array(array&&) = default;
|
||||||
|
|
||||||
constexpr array& operator=(const array& other) = default;
|
constexpr array& operator=(const array& other) = default;
|
||||||
constexpr array& operator=(array&& other) = default;
|
constexpr array& operator=(array&& other) = default;
|
||||||
@ -251,9 +250,6 @@ public:
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
constexpr std::size_t size() const noexcept {
|
|
||||||
return t_size;
|
|
||||||
}
|
|
||||||
|
|
||||||
constexpr data_t& operator[](std::size_t index) noexcept {
|
constexpr data_t& operator[](std::size_t index) noexcept {
|
||||||
return m_data[index];
|
return m_data[index];
|
||||||
|
|||||||
Loading…
Reference in New Issue
Block a user