xref: /aosp_15_r20/external/cronet/net/base/hex_utils.h (revision 6777b5387eb2ff775bb5750e3f5d96f37fb7352b)
1*6777b538SAndroid Build Coastguard Worker // Copyright 2017 The Chromium Authors
2*6777b538SAndroid Build Coastguard Worker // Use of this source code is governed by a BSD-style license that can be
3*6777b538SAndroid Build Coastguard Worker // found in the LICENSE file.
4*6777b538SAndroid Build Coastguard Worker 
5*6777b538SAndroid Build Coastguard Worker #ifndef NET_BASE_HEX_UTILS_H_
6*6777b538SAndroid Build Coastguard Worker #define NET_BASE_HEX_UTILS_H_
7*6777b538SAndroid Build Coastguard Worker 
8*6777b538SAndroid Build Coastguard Worker #include <string>
9*6777b538SAndroid Build Coastguard Worker #include <string_view>
10*6777b538SAndroid Build Coastguard Worker 
11*6777b538SAndroid Build Coastguard Worker #include "net/base/net_export.h"
12*6777b538SAndroid Build Coastguard Worker 
13*6777b538SAndroid Build Coastguard Worker namespace net {
14*6777b538SAndroid Build Coastguard Worker 
15*6777b538SAndroid Build Coastguard Worker // Use base::HexEncode() for encoding to hex representation.
16*6777b538SAndroid Build Coastguard Worker 
17*6777b538SAndroid Build Coastguard Worker // Decode a hex representation like "666f6f" to a string like "foo".  Crashes on
18*6777b538SAndroid Build Coastguard Worker // invalid input in debug builds, therefore it must only be used on sanitized
19*6777b538SAndroid Build Coastguard Worker // input (like a constant literal).  If validity of input needs to be checked or
20*6777b538SAndroid Build Coastguard Worker // partial decoding is desired, use base::HexStringToString() instead.
21*6777b538SAndroid Build Coastguard Worker NET_EXPORT_PRIVATE std::string HexDecode(std::string_view hex);
22*6777b538SAndroid Build Coastguard Worker 
23*6777b538SAndroid Build Coastguard Worker // Return a std::string containing hex and ASCII representations of the binary
24*6777b538SAndroid Build Coastguard Worker // buffer |input|, with offsets at the beginning of each line, in the style of
25*6777b538SAndroid Build Coastguard Worker // hexdump.  Non-printable characters will be shown as '.' in the ASCII output.
26*6777b538SAndroid Build Coastguard Worker // Example output:
27*6777b538SAndroid Build Coastguard Worker // "0x0000:  0090 69bd 5400 000d 610f 0189 0800 4500  ..i.T...a.....E.\n"
28*6777b538SAndroid Build Coastguard Worker // "0x0010:  001c fb98 4000 4001 7e18 d8ef 2301 455d  ....@.@.~...#.E]\n"
29*6777b538SAndroid Build Coastguard Worker // "0x0020:  7fe2 0800 6bcb 0bc6 806e                 ....k....n\n"
30*6777b538SAndroid Build Coastguard Worker NET_EXPORT_PRIVATE std::string HexDump(std::string_view input);
31*6777b538SAndroid Build Coastguard Worker 
32*6777b538SAndroid Build Coastguard Worker }  // namespace net
33*6777b538SAndroid Build Coastguard Worker 
34*6777b538SAndroid Build Coastguard Worker #endif  // NET_BASE_HEX_UTILS_H_
35