/* * Copyright 2004 The WebRTC Project Authors. All rights reserved. * * Use of this source code is governed by a BSD-style license * that can be found in the LICENSE file in the root of the source * tree. An additional intellectual property rights grant can be found * in the file PATENTS. All contributing project authors may * be found in the AUTHORS file in the root of the source tree. */ #ifndef RTC_BASE_STRING_ENCODE_H_ #define RTC_BASE_STRING_ENCODE_H_ #include #include #include #include #include #include "absl/strings/string_view.h" #include "api/array_view.h" #include "rtc_base/checks.h" #include "rtc_base/string_to_number.h" #include "rtc_base/strings/string_format.h" // IWYU pragma: keep namespace webrtc { inline std::string BoolToString(bool b) { return b ? "true" : "false"; } std::string hex_encode(absl::string_view str); std::string hex_encode_with_delimiter(absl::string_view source, char delimiter); // hex_decode converts ascii hex to binary. size_t hex_decode(ArrayView buffer, absl::string_view source); // hex_decode, assuming that there is a delimiter between every byte // pair. // `delimiter` == 0 means no delimiter // If the buffer is too short or the data is invalid, we return 0. size_t hex_decode_with_delimiter(ArrayView buffer, absl::string_view source, char delimiter); // Splits the source string into multiple fields separated by delimiter, // with duplicates of delimiter creating empty fields. Empty input produces a // single, empty, field. std::vector split(absl::string_view source, char delimiter); // Splits the source string into multiple fields separated by delimiter, // with duplicates of delimiter ignored. Trailing delimiter ignored. size_t tokenize(absl::string_view source, char delimiter, std::vector* fields); // Extract the first token from source as separated by delimiter, with // duplicates of delimiter ignored. Return false if the delimiter could not be // found, otherwise return true. bool tokenize_first(absl::string_view source, char delimiter, std::string* token, std::string* rest); // Versions that behave differently from StrCat // Versions not supported by StrCat: template ::value && !std::is_same::value, int>::type = 0> static bool FromString(absl::string_view s, T* t) { RTC_DCHECK(t); std::optional result = StringToNumber(s); if (result) *t = *result; return result.has_value(); } bool FromString(absl::string_view s, bool* b); template static inline T FromString(absl::string_view str) { T val; FromString(str, &val); return val; } ////////////////////////////////////////////////////////////////////// } // namespace webrtc #endif // RTC_BASE_STRING_ENCODE_H__