#ifndef TOOLKIT_H #define TOOLKIT_H #include #include #include #include #include #include #include #include #include #include #include namespace ranges = std::ranges; namespace views = std::ranges::views; // use for to_chars constexpr size_t buffer_size = 32; template concept _num_type = requires { std::is_same_v || std::is_same_v || std::is_same_v || std::is_same_v; }; namespace toolkit { enum class num_type{ BIN, HEX, OCT, DEC }; template inline std::expected to_string(T value) { if constexpr (std::is_same_v || std::is_same_v || std::is_same_v) { char buffer[buffer_size]; auto res = std::to_chars(buffer, buffer + buffer_size, value); if (res.ec != std::errc()) { return std::unexpected(std::make_error_code(res.ec).message()); } return std::string(buffer, res.ptr - buffer); } else if constexpr (std::is_same_v::type, char *>) { return std::to_string(value); } } template // requires std::is_same_v inline std::expected stoi(const std::string &str) { T value; auto res = std::from_chars(str.c_str(), str.c_str() + str.size(), value); if (res.ec != std::errc()) { return std::unexpected(std::make_error_code(res.ec).message()); } return value; } template requires std::is_same_v || std::is_same_v inline std::string replace_string(const std::string &str, T d, T e) { std::string result = str; if (d == e) { return result; } size_t len = 0; while (true) { auto pos = result.find(d); if (pos == std::string::npos) { return result; } if constexpr (std::is_same_v) { len = std::strlen(d); } else { len = d.length(); } result = result.replace(pos, len, e); } } template requires std::is_same_v || std::is_same_v inline std::vector split(T str, T d) { auto v = views::split(str, d) | views::transform([](auto word) { return T(word.begin(), word.end()); }); return std::vector(v.begin(), v.end()); } template requires std::is_same_v || std::is_same_v double round(T value, int c){ auto temp = 1; for(int i=0;i