blob: fad0d7a3a6826e8154afa4520c073d9708febed8 [file] [log] [blame]
#pragma once
#include <cstring>
#include <string>
#include <string_view>
#include <utility>
namespace stdplus
{
namespace util
{
namespace detail
{
template <typename... Views>
void strAppendViews(std::string& dst, Views... views)
{
dst.reserve((dst.size() + ... + views.size()));
(dst.append(views), ...);
}
} // namespace detail
/** @brief Converts the string into its underlying nul-terminated c-str
*
* @param[in] str - The string reference
* @return The c-str
*/
template <typename Str, typename = std::enable_if_t<
std::is_same_v<std::remove_cv_t<Str>, std::string>>>
auto cStr(Str& str)
{
return str.data();
}
template <
typename Str,
typename = std::enable_if_t<
std::is_pointer_v<Str> &&
std::is_same_v<std::remove_cv_t<std::remove_pointer_t<Str>>, char>>>
auto cStr(Str str)
{
return str;
}
/** @brief Appends multiple strings to the end of the destination string
* in the most optimal way for the given inputs.
*
* @param[in, out] dst - The string being appended to
* @param[in] ...strs - An arbitrary number of strings to concatenate
*/
template <typename... Strs>
void strAppend(std::string& dst, const Strs&... strs)
{
detail::strAppendViews(dst, std::string_view(strs)...);
}
/** @brief Concatenates multiple strings together in the most optimal
* way for the given inputs.
*
* @param[in] ...strs - An arbitrary number of strings to concatenate
* @return The concatenated result string
*/
template <typename... Strs>
std::string strCat(const Strs&... strs)
{
std::string ret;
strAppend(ret, strs...);
return ret;
}
template <typename... Strs>
std::string strCat(std::string&& in, const Strs&... strs)
{
std::string ret = std::move(in);
strAppend(ret, strs...);
return ret;
}
} // namespace util
} // namespace stdplus