#ifndef OB_STRING_HH #define OB_STRING_HH #include #include #include #include #include #include namespace OB::String { std::string to_string(double const val, int const pre = 2); std::vector split(std::string const& str, std::string const& delim, std::size_t size = std::numeric_limits::max()); std::vector split_view(std::string_view str, std::string_view delim, std::size_t size = std::numeric_limits::max()); std::string lowercase(std::string const& str); std::string trim(std::string str); bool assert_rx(std::string const& str, std::regex rx); std::optional> match(std::string const& str, std::regex rx); std::string repeat(std::size_t const num, std::string const& str); bool starts_with(std::string const& str, std::string const& val); std::string escape(std::string str); std::string unescape(std::string str); std::size_t count(std::string const& str, std::string const& val); std::size_t damerau_levenshtein(std::string const& lhs, std::string const& rhs, std::size_t const weight_insert = 1, std::size_t const weight_substitute = 1, std::size_t const weight_delete = 1, std::size_t const weight_transpose = 1); } // namespace OB::String #endif // OB_STRING_HH