xref: /aosp_15_r20/external/webrtc/rtc_base/string_utils.h (revision d9f758449e529ab9291ac668be2861e7a55c2422)
1*d9f75844SAndroid Build Coastguard Worker /*
2*d9f75844SAndroid Build Coastguard Worker  *  Copyright 2004 The WebRTC Project Authors. All rights reserved.
3*d9f75844SAndroid Build Coastguard Worker  *
4*d9f75844SAndroid Build Coastguard Worker  *  Use of this source code is governed by a BSD-style license
5*d9f75844SAndroid Build Coastguard Worker  *  that can be found in the LICENSE file in the root of the source
6*d9f75844SAndroid Build Coastguard Worker  *  tree. An additional intellectual property rights grant can be found
7*d9f75844SAndroid Build Coastguard Worker  *  in the file PATENTS.  All contributing project authors may
8*d9f75844SAndroid Build Coastguard Worker  *  be found in the AUTHORS file in the root of the source tree.
9*d9f75844SAndroid Build Coastguard Worker  */
10*d9f75844SAndroid Build Coastguard Worker 
11*d9f75844SAndroid Build Coastguard Worker #ifndef RTC_BASE_STRING_UTILS_H_
12*d9f75844SAndroid Build Coastguard Worker #define RTC_BASE_STRING_UTILS_H_
13*d9f75844SAndroid Build Coastguard Worker 
14*d9f75844SAndroid Build Coastguard Worker #include <stdio.h>
15*d9f75844SAndroid Build Coastguard Worker #include <string.h>
16*d9f75844SAndroid Build Coastguard Worker 
17*d9f75844SAndroid Build Coastguard Worker #include "absl/strings/string_view.h"
18*d9f75844SAndroid Build Coastguard Worker 
19*d9f75844SAndroid Build Coastguard Worker #if defined(WEBRTC_WIN)
20*d9f75844SAndroid Build Coastguard Worker #include <malloc.h>
21*d9f75844SAndroid Build Coastguard Worker #include <wchar.h>
22*d9f75844SAndroid Build Coastguard Worker #include <windows.h>
23*d9f75844SAndroid Build Coastguard Worker 
24*d9f75844SAndroid Build Coastguard Worker #endif  // WEBRTC_WIN
25*d9f75844SAndroid Build Coastguard Worker 
26*d9f75844SAndroid Build Coastguard Worker #if defined(WEBRTC_POSIX)
27*d9f75844SAndroid Build Coastguard Worker #include <stdlib.h>
28*d9f75844SAndroid Build Coastguard Worker #include <strings.h>
29*d9f75844SAndroid Build Coastguard Worker #endif  // WEBRTC_POSIX
30*d9f75844SAndroid Build Coastguard Worker 
31*d9f75844SAndroid Build Coastguard Worker #include <string>
32*d9f75844SAndroid Build Coastguard Worker 
33*d9f75844SAndroid Build Coastguard Worker #include "absl/strings/string_view.h"
34*d9f75844SAndroid Build Coastguard Worker 
35*d9f75844SAndroid Build Coastguard Worker namespace rtc {
36*d9f75844SAndroid Build Coastguard Worker 
37*d9f75844SAndroid Build Coastguard Worker const size_t SIZE_UNKNOWN = static_cast<size_t>(-1);
38*d9f75844SAndroid Build Coastguard Worker 
39*d9f75844SAndroid Build Coastguard Worker // An absl::string_view comparator functor for use with container types such as
40*d9f75844SAndroid Build Coastguard Worker // std::map that support heterogenous lookup.
41*d9f75844SAndroid Build Coastguard Worker //
42*d9f75844SAndroid Build Coastguard Worker // Example usage:
43*d9f75844SAndroid Build Coastguard Worker // std::map<std::string, int, rtc::AbslStringViewCmp> my_map;
44*d9f75844SAndroid Build Coastguard Worker struct AbslStringViewCmp {
45*d9f75844SAndroid Build Coastguard Worker   using is_transparent = void;
operatorAbslStringViewCmp46*d9f75844SAndroid Build Coastguard Worker   bool operator()(absl::string_view a, absl::string_view b) const {
47*d9f75844SAndroid Build Coastguard Worker     return a < b;
48*d9f75844SAndroid Build Coastguard Worker   }
49*d9f75844SAndroid Build Coastguard Worker };
50*d9f75844SAndroid Build Coastguard Worker 
51*d9f75844SAndroid Build Coastguard Worker // Safe version of strncpy that always nul-terminate.
52*d9f75844SAndroid Build Coastguard Worker size_t strcpyn(char* buffer, size_t buflen, absl::string_view source);
53*d9f75844SAndroid Build Coastguard Worker 
54*d9f75844SAndroid Build Coastguard Worker ///////////////////////////////////////////////////////////////////////////////
55*d9f75844SAndroid Build Coastguard Worker // UTF helpers (Windows only)
56*d9f75844SAndroid Build Coastguard Worker ///////////////////////////////////////////////////////////////////////////////
57*d9f75844SAndroid Build Coastguard Worker 
58*d9f75844SAndroid Build Coastguard Worker #if defined(WEBRTC_WIN)
59*d9f75844SAndroid Build Coastguard Worker 
ToUtf16(const char * utf8,size_t len)60*d9f75844SAndroid Build Coastguard Worker inline std::wstring ToUtf16(const char* utf8, size_t len) {
61*d9f75844SAndroid Build Coastguard Worker   if (len == 0)
62*d9f75844SAndroid Build Coastguard Worker     return std::wstring();
63*d9f75844SAndroid Build Coastguard Worker   int len16 = ::MultiByteToWideChar(CP_UTF8, 0, utf8, static_cast<int>(len),
64*d9f75844SAndroid Build Coastguard Worker                                     nullptr, 0);
65*d9f75844SAndroid Build Coastguard Worker   std::wstring ws(len16, 0);
66*d9f75844SAndroid Build Coastguard Worker   ::MultiByteToWideChar(CP_UTF8, 0, utf8, static_cast<int>(len), &*ws.begin(),
67*d9f75844SAndroid Build Coastguard Worker                         len16);
68*d9f75844SAndroid Build Coastguard Worker   return ws;
69*d9f75844SAndroid Build Coastguard Worker }
70*d9f75844SAndroid Build Coastguard Worker 
ToUtf16(absl::string_view str)71*d9f75844SAndroid Build Coastguard Worker inline std::wstring ToUtf16(absl::string_view str) {
72*d9f75844SAndroid Build Coastguard Worker   return ToUtf16(str.data(), str.length());
73*d9f75844SAndroid Build Coastguard Worker }
74*d9f75844SAndroid Build Coastguard Worker 
ToUtf8(const wchar_t * wide,size_t len)75*d9f75844SAndroid Build Coastguard Worker inline std::string ToUtf8(const wchar_t* wide, size_t len) {
76*d9f75844SAndroid Build Coastguard Worker   if (len == 0)
77*d9f75844SAndroid Build Coastguard Worker     return std::string();
78*d9f75844SAndroid Build Coastguard Worker   int len8 = ::WideCharToMultiByte(CP_UTF8, 0, wide, static_cast<int>(len),
79*d9f75844SAndroid Build Coastguard Worker                                    nullptr, 0, nullptr, nullptr);
80*d9f75844SAndroid Build Coastguard Worker   std::string ns(len8, 0);
81*d9f75844SAndroid Build Coastguard Worker   ::WideCharToMultiByte(CP_UTF8, 0, wide, static_cast<int>(len), &*ns.begin(),
82*d9f75844SAndroid Build Coastguard Worker                         len8, nullptr, nullptr);
83*d9f75844SAndroid Build Coastguard Worker   return ns;
84*d9f75844SAndroid Build Coastguard Worker }
85*d9f75844SAndroid Build Coastguard Worker 
ToUtf8(const wchar_t * wide)86*d9f75844SAndroid Build Coastguard Worker inline std::string ToUtf8(const wchar_t* wide) {
87*d9f75844SAndroid Build Coastguard Worker   return ToUtf8(wide, wcslen(wide));
88*d9f75844SAndroid Build Coastguard Worker }
89*d9f75844SAndroid Build Coastguard Worker 
ToUtf8(const std::wstring & wstr)90*d9f75844SAndroid Build Coastguard Worker inline std::string ToUtf8(const std::wstring& wstr) {
91*d9f75844SAndroid Build Coastguard Worker   return ToUtf8(wstr.data(), wstr.length());
92*d9f75844SAndroid Build Coastguard Worker }
93*d9f75844SAndroid Build Coastguard Worker 
94*d9f75844SAndroid Build Coastguard Worker #endif  // WEBRTC_WIN
95*d9f75844SAndroid Build Coastguard Worker 
96*d9f75844SAndroid Build Coastguard Worker // TODO(jonasolsson): replace with absl::Hex when that becomes available.
97*d9f75844SAndroid Build Coastguard Worker std::string ToHex(int i);
98*d9f75844SAndroid Build Coastguard Worker 
99*d9f75844SAndroid Build Coastguard Worker // CompileTimeString comprises of a string-like object which can be used as a
100*d9f75844SAndroid Build Coastguard Worker // regular const char* in compile time and supports concatenation. Useful for
101*d9f75844SAndroid Build Coastguard Worker // concatenating constexpr strings in for example macro declarations.
102*d9f75844SAndroid Build Coastguard Worker namespace rtc_base_string_utils_internal {
103*d9f75844SAndroid Build Coastguard Worker template <int NPlus1>
104*d9f75844SAndroid Build Coastguard Worker struct CompileTimeString {
105*d9f75844SAndroid Build Coastguard Worker   char string[NPlus1] = {0};
106*d9f75844SAndroid Build Coastguard Worker   constexpr CompileTimeString() = default;
107*d9f75844SAndroid Build Coastguard Worker   template <int MPlus1>
CompileTimeStringCompileTimeString108*d9f75844SAndroid Build Coastguard Worker   explicit constexpr CompileTimeString(const char (&chars)[MPlus1]) {
109*d9f75844SAndroid Build Coastguard Worker     char* chars_pointer = string;
110*d9f75844SAndroid Build Coastguard Worker     for (auto c : chars)
111*d9f75844SAndroid Build Coastguard Worker       *chars_pointer++ = c;
112*d9f75844SAndroid Build Coastguard Worker   }
113*d9f75844SAndroid Build Coastguard Worker   template <int MPlus1>
ConcatCompileTimeString114*d9f75844SAndroid Build Coastguard Worker   constexpr auto Concat(CompileTimeString<MPlus1> b) {
115*d9f75844SAndroid Build Coastguard Worker     CompileTimeString<NPlus1 + MPlus1 - 1> result;
116*d9f75844SAndroid Build Coastguard Worker     char* chars_pointer = result.string;
117*d9f75844SAndroid Build Coastguard Worker     for (auto c : string)
118*d9f75844SAndroid Build Coastguard Worker       *chars_pointer++ = c;
119*d9f75844SAndroid Build Coastguard Worker     chars_pointer = result.string + NPlus1 - 1;
120*d9f75844SAndroid Build Coastguard Worker     for (auto c : b.string)
121*d9f75844SAndroid Build Coastguard Worker       *chars_pointer++ = c;
122*d9f75844SAndroid Build Coastguard Worker     result.string[NPlus1 + MPlus1 - 2] = 0;
123*d9f75844SAndroid Build Coastguard Worker     return result;
124*d9f75844SAndroid Build Coastguard Worker   }
125*d9f75844SAndroid Build Coastguard Worker   constexpr operator const char*() { return string; }
126*d9f75844SAndroid Build Coastguard Worker };
127*d9f75844SAndroid Build Coastguard Worker }  // namespace rtc_base_string_utils_internal
128*d9f75844SAndroid Build Coastguard Worker 
129*d9f75844SAndroid Build Coastguard Worker // Makes a constexpr CompileTimeString<X> without having to specify X
130*d9f75844SAndroid Build Coastguard Worker // explicitly.
131*d9f75844SAndroid Build Coastguard Worker template <int N>
MakeCompileTimeString(const char (& a)[N])132*d9f75844SAndroid Build Coastguard Worker constexpr auto MakeCompileTimeString(const char (&a)[N]) {
133*d9f75844SAndroid Build Coastguard Worker   return rtc_base_string_utils_internal::CompileTimeString<N>(a);
134*d9f75844SAndroid Build Coastguard Worker }
135*d9f75844SAndroid Build Coastguard Worker 
136*d9f75844SAndroid Build Coastguard Worker }  // namespace rtc
137*d9f75844SAndroid Build Coastguard Worker 
138*d9f75844SAndroid Build Coastguard Worker #endif  // RTC_BASE_STRING_UTILS_H_
139