2021-01-16 22:33:05 +08:00
|
|
|
#pragma once
|
|
|
|
|
|
|
|
#include <nlohmann/detail/macro_scope.hpp>
|
|
|
|
|
|
|
|
namespace nlohmann
|
|
|
|
{
|
|
|
|
namespace detail
|
|
|
|
{
|
|
|
|
|
|
|
|
/*!
|
|
|
|
@brief replace all occurrences of a substring by another string
|
|
|
|
|
|
|
|
@param[in,out] s the string to manipulate; changed so that all
|
|
|
|
occurrences of @a f are replaced with @a t
|
|
|
|
@param[in] f the substring to replace with @a t
|
|
|
|
@param[in] t the string to replace @a f
|
|
|
|
|
|
|
|
@pre The search string @a f must not be empty. **This precondition is
|
|
|
|
enforced with an assertion.**
|
|
|
|
|
|
|
|
@since version 2.0.0
|
|
|
|
*/
|
2022-04-12 20:18:16 +08:00
|
|
|
template<typename StringType>
|
|
|
|
inline void replace_substring(StringType& s, const StringType& f,
|
|
|
|
const StringType& t)
|
2021-01-16 22:33:05 +08:00
|
|
|
{
|
|
|
|
JSON_ASSERT(!f.empty());
|
|
|
|
for (auto pos = s.find(f); // find first occurrence of f
|
2022-04-12 20:18:16 +08:00
|
|
|
pos != StringType::npos; // make sure f was found
|
2021-01-16 22:33:05 +08:00
|
|
|
s.replace(pos, f.size(), t), // replace with t, and
|
|
|
|
pos = s.find(f, pos + t.size())) // find next occurrence of f
|
|
|
|
{}
|
|
|
|
}
|
|
|
|
|
|
|
|
/*!
|
|
|
|
* @brief string escaping as described in RFC 6901 (Sect. 4)
|
|
|
|
* @param[in] s string to escape
|
|
|
|
* @return escaped string
|
|
|
|
*
|
|
|
|
* Note the order of escaping "~" to "~0" and "/" to "~1" is important.
|
|
|
|
*/
|
2022-04-12 20:18:16 +08:00
|
|
|
template<typename StringType>
|
|
|
|
inline StringType escape(StringType s)
|
2021-01-16 22:33:05 +08:00
|
|
|
{
|
2022-04-12 20:18:16 +08:00
|
|
|
replace_substring(s, StringType{"~"}, StringType{"~0"});
|
|
|
|
replace_substring(s, StringType{"/"}, StringType{"~1"});
|
2021-01-16 22:33:05 +08:00
|
|
|
return s;
|
|
|
|
}
|
|
|
|
|
|
|
|
/*!
|
|
|
|
* @brief string unescaping as described in RFC 6901 (Sect. 4)
|
|
|
|
* @param[in] s string to unescape
|
|
|
|
* @return unescaped string
|
|
|
|
*
|
|
|
|
* Note the order of escaping "~1" to "/" and "~0" to "~" is important.
|
|
|
|
*/
|
2022-04-12 20:18:16 +08:00
|
|
|
template<typename StringType>
|
|
|
|
static void unescape(StringType& s)
|
2021-01-16 22:33:05 +08:00
|
|
|
{
|
2022-04-12 20:18:16 +08:00
|
|
|
replace_substring(s, StringType{"~1"}, StringType{"/"});
|
|
|
|
replace_substring(s, StringType{"~0"}, StringType{"~"});
|
2021-01-16 22:33:05 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
} // namespace detail
|
|
|
|
} // namespace nlohmann
|