add split function

This commit is contained in:
JIe 2025-01-06 17:44:00 +08:00
parent 0e57341bec
commit d12728ddb5

View File

@ -8,6 +8,11 @@
#include <string>
#include <cstdlib>
#include <ios>
#include <vector>
#include <ranges>
namespace ranges = std::ranges;
namespace views = std::ranges::views;
// use for to_chars
constexpr size_t buffer_size = 32;
@ -20,27 +25,35 @@ concept _num_type = requires {
std::is_same_v<T, double>;
};
namespace toolkit{
namespace toolkit
{
template <typename T>
std::expected<std::string, std::string> to_string(T value){
if constexpr (std::is_same_v<T, int> || std::is_same_v<T, float> || std::is_same_v<T, double>){
std::expected<std::string, std::string> to_string(T value)
{
if constexpr (std::is_same_v<T, int> || std::is_same_v<T, float> || std::is_same_v<T, double>)
{
char buffer[buffer_size];
auto res = std::to_chars(buffer, buffer + buffer_size, value);
if (res.ec != std::errc()) {
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<typename std::remove_const<T>::type,
char *>) {
}
else if constexpr (std::is_same_v<typename std::remove_const<T>::type,
char *>)
{
return std::to_string(value);
}
}
template <typename T = double> // requires std::is_same_v<T, std::string>
std::expected<T, std::string> stoi(const std::string& str){
std::expected<T, std::string> 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()){
if (res.ec != std::errc())
{
return std::unexpected(std::make_error_code(res.ec).message());
}
return value;
@ -48,25 +61,43 @@ namespace toolkit{
template <typename T>
requires std::is_same_v<std::string, T> || std::is_same_v<const char *, T>
std::string replace_string(const std::string& str, T d, T e){
std::string replace_string(const std::string &str, T d, T e)
{
std::string result = str;
if(d == e){
if (d == e)
{
return result;
}
size_t len = 0;
while(true){
while (true)
{
auto pos = result.find(d);
if(pos == std::string::npos){
if (pos == std::string::npos)
{
return result;
}
if constexpr(std::is_same_v<T, const char*>){
if constexpr (std::is_same_v<T, const char *>)
{
len = std::strlen(d);
}else{
}
else
{
len = d.length();
}
result = result.replace(pos, len, e);
}
}
template <typename T = std::string>
requires std::is_same_v<T, std::string> ||
std::is_same_v<T, std::string_view>
std::vector<T> split(T str, T d)
{
auto v = views::split(str, d) | views::transform([](auto word)
{ return T(word.begin(), word.end()); });
return std::vector<T>(v.begin(), v.end());
}
}
#endif