GCC Code Coverage Report
Directory: ./ Exec Total Coverage
File: json_utils.cc Lines: 37 37 100.0 %
Date: 2022-06-15 16:51:59 Branches: 19 20 95.0 %

Line Branch Exec Source
1
#include "json_utils.h"
2
3
namespace node {
4
5
29404
std::string EscapeJsonChars(const std::string& str) {
6
  const std::string control_symbols[0x20] = {
7
      "\\u0000", "\\u0001", "\\u0002", "\\u0003", "\\u0004", "\\u0005",
8
      "\\u0006", "\\u0007", "\\b",     "\\t",     "\\n",     "\\u000b",
9
      "\\f",     "\\r",     "\\u000e", "\\u000f", "\\u0010", "\\u0011",
10
      "\\u0012", "\\u0013", "\\u0014", "\\u0015", "\\u0016", "\\u0017",
11
      "\\u0018", "\\u0019", "\\u001a", "\\u001b", "\\u001c", "\\u001d",
12
999736
      "\\u001e", "\\u001f"};
13
14
29404
  std::string ret;
15
29404
  size_t last_pos = 0;
16
29404
  size_t pos = 0;
17
365978
  for (; pos < str.size(); ++pos) {
18
673148
    std::string replace;
19
336574
    char ch = str[pos];
20
336574
    if (ch == '\\') {
21
1
      replace = "\\\\";
22
336573
    } else if (ch == '\"') {
23
5
      replace = "\\\"";
24
    } else {
25
336568
      size_t num = static_cast<size_t>(ch);
26
336568
      if (num < 0x20) replace = control_symbols[num];
27
    }
28
336574
    if (!replace.empty()) {
29
72
      if (pos > last_pos) {
30
40
        ret += str.substr(last_pos, pos - last_pos);
31
      }
32
72
      last_pos = pos + 1;
33
72
      ret += replace;
34
    }
35
  }
36
  // Append any remaining symbols.
37
29404
  if (last_pos < str.size()) {
38
29313
    ret += str.substr(last_pos, pos - last_pos);
39
  }
40
29404
  return ret;
41
}
42
43
2
std::string Reindent(const std::string& str, int indent_depth) {
44
2
  if (indent_depth <= 0) return str;
45
4
  const std::string indent(indent_depth, ' ');
46
4
  std::string out;
47
2
  std::string::size_type pos = 0;
48
  for (;;) {
49
2500
    std::string::size_type prev_pos = pos;
50
2500
    pos = str.find('\n', pos);
51
52
2500
    out.append(indent);
53
54
2500
    if (pos == std::string::npos) {
55
2
      out.append(str, prev_pos, std::string::npos);
56
2
      break;
57
    } else {
58
2498
      pos++;
59
2498
      out.append(str, prev_pos, pos - prev_pos);
60
    }
61
2498
  }
62
63
2
  return out;
64
}
65
66
}  // namespace node