GCC Code Coverage Report


Directory: ../
Coverage: low: ≥ 0% medium: ≥ 75.0% high: ≥ 90.0%
Coverage Exec / Excl / Total
Lines: 93.5% 159 / 3 / 173
Functions: 100.0% 13 / 0 / 13
Branches: 59.0% 177 / 8 / 308

src/irgenerator/NameMangling.cpp
Line Branch Exec Source
1 // Copyright (c) 2021-2026 ChilliBits. All rights reserved.
2
3 #include "NameMangling.h"
4
5 #include <exception/CompilerError.h>
6 #include <model/Function.h>
7 #include <model/GenericType.h>
8 #include <model/Interface.h>
9 #include <model/Struct.h>
10 #include <symboltablebuilder/SymbolTableEntry.h>
11 #include <symboltablebuilder/Type.h>
12 #include <util/CommonUtil.h>
13
14 namespace spice::compiler {
15
16 /**
17 * Mangle a function or procedure.
18 * This should be mostly compatible with the C++ Itanium ABI name mangling scheme.
19 *
20 * @param spiceFunc Input function
21 * @return Mangled name
22 */
23 34086 std::string NameMangling::mangleFunction(const Function &spiceFunc) {
24 // Check if we have a predefined mangled name, specified by e.g. a function attribute
25
1/2
✗ Branch 3 → 4 not taken.
✓ Branch 3 → 6 taken 34086 times.
34086 if (!spiceFunc.predefinedMangledName.empty())
26 return spiceFunc.predefinedMangledName;
27
28 // Check if mangling is required
29
1/2
✗ Branch 6 → 7 not taken.
✓ Branch 6 → 9 taken 34086 times.
34086 if (!spiceFunc.mangleFunctionName)
30 return spiceFunc.name;
31
32
1/2
✓ Branch 9 → 10 taken 34086 times.
✗ Branch 9 → 104 not taken.
34086 std::stringstream mangledName;
33
1/2
✓ Branch 10 → 11 taken 34086 times.
✗ Branch 10 → 102 not taken.
34086 mangledName << "_Z";
34
35 // This type
36
2/2
✓ Branch 14 → 15 taken 20741 times.
✓ Branch 14 → 17 taken 13345 times.
34086 if (spiceFunc.isMethod()) {
37
1/2
✓ Branch 15 → 16 taken 20741 times.
✗ Branch 15 → 102 not taken.
20741 mangledName << "N";
38
1/2
✓ Branch 16 → 17 taken 20741 times.
✗ Branch 16 → 102 not taken.
20741 mangleType(mangledName, spiceFunc.thisType);
39 }
40
41 // Function name
42
1/2
✓ Branch 17 → 18 taken 34086 times.
✗ Branch 17 → 102 not taken.
34086 const std::string name = spiceFunc.name + spiceFunc.mangleSuffix;
43
2/4
✓ Branch 19 → 20 taken 34086 times.
✗ Branch 19 → 100 not taken.
✓ Branch 20 → 21 taken 34086 times.
✗ Branch 20 → 100 not taken.
34086 mangledName << name.length() << name;
44
45 // Template types
46
1/2
✓ Branch 22 → 23 taken 34086 times.
✗ Branch 22 → 100 not taken.
34086 bool isSelfGeneric = !spiceFunc.templateTypes.empty();
47
2/2
✓ Branch 25 → 26 taken 20741 times.
✓ Branch 25 → 30 taken 13345 times.
34086 if (spiceFunc.isMethod())
48
1/2
✓ Branch 27 → 28 taken 20741 times.
✗ Branch 27 → 100 not taken.
20741 isSelfGeneric = spiceFunc.templateTypes.size() > spiceFunc.thisType.getTemplateTypes().size();
49
2/2
✓ Branch 30 → 31 taken 3926 times.
✓ Branch 30 → 57 taken 30160 times.
34086 if (isSelfGeneric) {
50
1/2
✓ Branch 31 → 32 taken 3926 times.
✗ Branch 31 → 100 not taken.
3926 mangledName << "I";
51 // Template types themselves
52
2/2
✓ Branch 44 → 34 taken 6596 times.
✓ Branch 44 → 45 taken 3926 times.
10522 for (const GenericType &genericTemplateType : spiceFunc.templateTypes) {
53
3/6
✓ Branch 35 → 36 taken 6596 times.
✗ Branch 35 → 93 not taken.
✓ Branch 36 → 37 taken 6596 times.
✗ Branch 36 → 93 not taken.
✗ Branch 37 → 38 not taken.
✓ Branch 37 → 39 taken 6596 times.
6596 assert(spiceFunc.typeMapping.contains(genericTemplateType.getSubType()));
54
2/4
✓ Branch 39 → 40 taken 6596 times.
✗ Branch 39 → 93 not taken.
✓ Branch 40 → 41 taken 6596 times.
✗ Branch 40 → 93 not taken.
6596 const QualType &actualType = spiceFunc.typeMapping.at(genericTemplateType.getSubType());
55
1/2
✓ Branch 41 → 42 taken 6596 times.
✗ Branch 41 → 93 not taken.
6596 mangleType(mangledName, actualType);
56 }
57
1/2
✓ Branch 45 → 46 taken 3926 times.
✗ Branch 45 → 100 not taken.
3926 mangledName << "E";
58
59 // Insert second end marker to end the nested type
60
2/2
✓ Branch 49 → 50 taken 622 times.
✓ Branch 49 → 51 taken 3304 times.
3926 if (spiceFunc.isMethod())
61
1/2
✓ Branch 50 → 51 taken 622 times.
✗ Branch 50 → 100 not taken.
622 mangledName << "E";
62
63 // Return type
64
2/2
✓ Branch 54 → 55 taken 1212 times.
✓ Branch 54 → 56 taken 2714 times.
3926 if (spiceFunc.isFunction())
65
1/2
✓ Branch 55 → 62 taken 1212 times.
✗ Branch 55 → 100 not taken.
1212 mangleType(mangledName, spiceFunc.returnType);
66 else
67
1/2
✓ Branch 56 → 62 taken 2714 times.
✗ Branch 56 → 100 not taken.
2714 mangledName << "v";
68
2/2
✓ Branch 60 → 61 taken 20119 times.
✓ Branch 60 → 62 taken 10041 times.
30160 } else if (spiceFunc.isMethod()) {
69
1/2
✓ Branch 61 → 62 taken 20119 times.
✗ Branch 61 → 100 not taken.
20119 mangledName << "E";
70 }
71
72 // Parameter types
73
2/2
✓ Branch 70 → 64 taken 37407 times.
✓ Branch 70 → 71 taken 34086 times.
71493 for (const auto &[qualType, isOptional] : spiceFunc.paramList) {
74
1/2
✗ Branch 65 → 66 not taken.
✓ Branch 65 → 67 taken 37407 times.
37407 assert(!isOptional);
75
1/2
✓ Branch 67 → 68 taken 37407 times.
✗ Branch 67 → 94 not taken.
37407 mangleType(mangledName, qualType);
76 }
77
2/2
✓ Branch 72 → 73 taken 11104 times.
✓ Branch 72 → 74 taken 22982 times.
34086 if (spiceFunc.paramList.empty())
78
1/2
✓ Branch 73 → 74 taken 11104 times.
✗ Branch 73 → 100 not taken.
11104 mangledName << "v";
79
80 #ifndef NDEBUG
81 34086 const TypeMapping &typeMapping = spiceFunc.typeMapping;
82
2/4
✓ Branch 74 → 75 taken 34086 times.
✗ Branch 74 → 96 not taken.
✓ Branch 75 → 76 taken 34086 times.
✗ Branch 75 → 95 not taken.
34086 const bool returnTypeIsFctOrProc = spiceFunc.returnType.getBase().isOneOf({TY_FUNCTION, TY_PROCEDURE});
83
2/4
✓ Branch 2 → 3 taken 37368 times.
✗ Branch 2 → 8 not taken.
✓ Branch 3 → 4 taken 37368 times.
✗ Branch 3 → 7 not taken.
37368 const auto paramPredicate = [](const Param &p) { return p.qualType.getBase().isOneOf({TY_FUNCTION, TY_PROCEDURE}); };
84
1/2
✓ Branch 76 → 77 taken 34086 times.
✗ Branch 76 → 100 not taken.
34086 const bool paramTypeIsFctOrProc = std::ranges::any_of(spiceFunc.paramList, paramPredicate);
85 13417 const auto templateTypePredicate = [&](const GenericType &t) {
86
2/2
✓ Branch 3 → 4 taken 13413 times.
✓ Branch 3 → 14 taken 4 times.
13417 if (t.is(TY_GENERIC)) {
87
1/2
✗ Branch 6 → 7 not taken.
✓ Branch 6 → 8 taken 13413 times.
13413 assert(typeMapping.contains(t.getSubType()));
88
4/8
✓ Branch 8 → 9 taken 13413 times.
✗ Branch 8 → 20 not taken.
✓ Branch 9 → 10 taken 13413 times.
✗ Branch 9 → 20 not taken.
✓ Branch 10 → 11 taken 13413 times.
✗ Branch 10 → 20 not taken.
✓ Branch 11 → 12 taken 13413 times.
✗ Branch 11 → 19 not taken.
13413 return typeMapping.at(t.getSubType()).getBase().isOneOf({TY_FUNCTION, TY_PROCEDURE});
89 }
90
2/4
✓ Branch 14 → 15 taken 4 times.
✗ Branch 14 → 22 not taken.
✓ Branch 15 → 16 taken 4 times.
✗ Branch 15 → 21 not taken.
4 return t.getBase().isOneOf({TY_FUNCTION, TY_PROCEDURE});
91 34086 };
92
1/2
✓ Branch 77 → 78 taken 34086 times.
✗ Branch 77 → 100 not taken.
34086 const bool templateTypeIsFctOrProc = std::ranges::any_of(spiceFunc.templateTypes, templateTypePredicate);
93
4/6
✓ Branch 78 → 79 taken 34086 times.
✗ Branch 78 → 87 not taken.
✓ Branch 79 → 80 taken 34027 times.
✓ Branch 79 → 87 taken 59 times.
✓ Branch 80 → 81 taken 34027 times.
✗ Branch 80 → 87 not taken.
34086 if (!returnTypeIsFctOrProc && !paramTypeIsFctOrProc && !templateTypeIsFctOrProc)
94
3/6
✓ Branch 81 → 82 taken 34027 times.
✗ Branch 81 → 99 not taken.
✓ Branch 82 → 83 taken 34027 times.
✗ Branch 82 → 97 not taken.
✗ Branch 83 → 84 not taken.
✓ Branch 83 → 85 taken 34027 times.
34027 assert(CommonUtil::isValidMangledName(mangledName.str()));
95 #endif
96
97
1/2
✓ Branch 87 → 88 taken 34086 times.
✗ Branch 87 → 100 not taken.
34086 return mangledName.str();
98 34086 }
99
100 /**
101 * Mangle a struct
102 * This should be mostly compatible with the C++ Itanium ABI name mangling scheme.
103 *
104 * @param spiceStruct Input struct
105 * @return Mangled name
106 */
107 2054 std::string NameMangling::mangleStruct(const Struct &spiceStruct) { return "struct." + spiceStruct.name; }
108
109 /**
110 * Mangle an interface
111 *
112 * @param spiceInterface Input interface
113 * @return Mangled name
114 */
115 287 std::string NameMangling::mangleInterface(const Interface &spiceInterface) { return "interface." + spiceInterface.name; }
116
117 /**
118 * Mangle a fully qualified name like e.g. test::s1::calledMethod to 4test2s112calledMethod
119 * This should be mostly compatible with the C++ Itanium ABI name mangling scheme.
120 *
121 * @param out Output string stream
122 * @param name Input name
123 * @param nestedType True if the name is a nested type
124 * @return Mangled name
125 */
126 36629 void NameMangling::mangleName(std::stringstream &out, const std::string &name, bool &nestedType) {
127 36629 std::vector<std::string> fragments;
128
1/2
✓ Branch 2 → 3 taken 36629 times.
✗ Branch 2 → 51 not taken.
36629 std::istringstream ss(name);
129 36629 std::string token;
130
131
4/6
✓ Branch 16 → 17 taken 73258 times.
✗ Branch 16 → 47 not taken.
✓ Branch 17 → 18 taken 73258 times.
✗ Branch 17 → 47 not taken.
✓ Branch 18 → 5 taken 36629 times.
✓ Branch 18 → 19 taken 36629 times.
73258 while (std::getline(ss, token, ':')) {
132
1/2
✓ Branch 5 → 6 taken 36629 times.
✗ Branch 5 → 42 not taken.
36629 std::istringstream subStream(token);
133 36629 std::string subToken;
134
4/6
✓ Branch 10 → 11 taken 73258 times.
✗ Branch 10 → 38 not taken.
✓ Branch 11 → 12 taken 73258 times.
✗ Branch 11 → 38 not taken.
✓ Branch 12 → 8 taken 36629 times.
✓ Branch 12 → 13 taken 36629 times.
73258 while (std::getline(subStream, subToken, '/')) {
135
1/2
✓ Branch 8 → 9 taken 36629 times.
✗ Branch 8 → 38 not taken.
36629 fragments.push_back(subToken);
136 }
137 36629 }
138
139 // Start a nested type if needed. The caller needs to emit the end marker.
140
1/2
✗ Branch 20 → 21 not taken.
✓ Branch 20 → 23 taken 36629 times.
36629 if (fragments.size() > 1) {
141 out << "N";
142 nestedType = true;
143 }
144
145 // Process each fragment and append it to the result
146
2/2
✓ Branch 33 → 25 taken 36629 times.
✓ Branch 33 → 34 taken 36629 times.
73258 for (const std::string &fragment : fragments) {
147 36629 int fragmentLength = static_cast<int>(fragment.length());
148
2/4
✓ Branch 28 → 29 taken 36629 times.
✗ Branch 28 → 43 not taken.
✓ Branch 29 → 30 taken 36629 times.
✗ Branch 29 → 43 not taken.
36629 out << std::to_string(fragmentLength) << fragment;
149 }
150 36629 }
151
152 /**
153 * Mangle a symbol qualType
154 * This should be mostly compatible with the C++ Itanium ABI name mangling scheme.
155 *
156 * @param out Output string stream
157 * @param qualType Input symbol qualType
158 * @return Mangled name
159 */
160 84554 void NameMangling::mangleType(std::stringstream &out, const QualType &qualType) { // NOLINT(*-no-recursion)
161 84554 const Type *type = qualType.getType();
162
1/2
✗ Branch 4 → 5 not taken.
✓ Branch 4 → 6 taken 84554 times.
84554 assert(!qualType.hasAnyGenericParts());
163
164 // Unwrap qualType chain
165
1/2
✗ Branch 7 → 8 not taken.
✓ Branch 7 → 9 taken 84554 times.
84554 assert(!type->typeChain.empty());
166
2/2
✓ Branch 14 → 11 taken 10541 times.
✓ Branch 14 → 15 taken 84554 times.
95095 for (size_t i = type->typeChain.size() - 1; i >= 1; i--)
167 10541 mangleTypeChainElement(out, type->typeChain.at(i), false);
168
169 // Qualifiers
170
1/2
✗ Branch 17 → 18 not taken.
✓ Branch 17 → 19 taken 84554 times.
84554 assert(qualType.getQualifiers().isSigned == !qualType.getQualifiers().isUnsigned);
171 84554 const bool signedness = qualType.getQualifiers().isSigned;
172
6/6
✓ Branch 21 → 22 taken 13724 times.
✓ Branch 21 → 25 taken 70830 times.
✓ Branch 23 → 24 taken 5514 times.
✓ Branch 23 → 25 taken 8210 times.
✓ Branch 26 → 27 taken 5514 times.
✓ Branch 26 → 28 taken 79040 times.
84554 if (qualType.getQualifiers().isConst && type->typeChain.size() > 1)
173 5514 out << "K";
174
175 // Base chain element
176 84554 mangleTypeChainElement(out, type->typeChain.front(), signedness);
177 84554 }
178
179 /**
180 * Mangle a type chain element
181 *
182 * @param out Output string stream
183 * @param chainElement Input type chain element
184 * @param signedness Signedness of the type
185 * @return Mangled name
186 */
187 95095 void NameMangling::mangleTypeChainElement(std::stringstream &out, const TypeChainElement &chainElement, bool signedness) {
188
14/16
✓ Branch 2 → 3 taken 3023 times.
✓ Branch 2 → 5 taken 124 times.
✓ Branch 2 → 11 taken 7394 times.
✓ Branch 2 → 13 taken 2456 times.
✓ Branch 2 → 17 taken 10752 times.
✓ Branch 2 → 22 taken 2729 times.
✓ Branch 2 → 27 taken 8193 times.
✓ Branch 2 → 32 taken 2506 times.
✓ Branch 2 → 37 taken 7125 times.
✓ Branch 2 → 39 taken 10692 times.
✓ Branch 2 → 41 taken 3373 times.
✓ Branch 2 → 45 taken 36629 times.
✗ Branch 2 → 61 not taken.
✓ Branch 2 → 66 taken 34 times.
✓ Branch 2 → 79 taken 65 times.
✗ Branch 2 → 91 not taken.
95095 switch (chainElement.superType) {
189 3023 case TY_PTR:
190
1/2
✓ Branch 3 → 4 taken 3023 times.
✗ Branch 3 → 115 not taken.
3023 out << "P";
191 3023 break;
192 124 case TY_ARRAY:
193
2/2
✓ Branch 5 → 6 taken 76 times.
✓ Branch 5 → 7 taken 48 times.
124 if (chainElement.data.arraySize == ARRAY_SIZE_UNKNOWN)
194
1/2
✓ Branch 6 → 10 taken 76 times.
✗ Branch 6 → 115 not taken.
76 out << "P";
195 else
196
3/6
✓ Branch 7 → 8 taken 48 times.
✗ Branch 7 → 115 not taken.
✓ Branch 8 → 9 taken 48 times.
✗ Branch 8 → 115 not taken.
✓ Branch 9 → 10 taken 48 times.
✗ Branch 9 → 115 not taken.
48 out << "A" << chainElement.data.arraySize << "_";
197 124 break;
198 7394 case TY_REF:
199
1/2
✓ Branch 11 → 12 taken 7394 times.
✗ Branch 11 → 115 not taken.
7394 out << "R";
200 7394 break;
201 2456 case TY_DOUBLE:
202
1/2
✗ Branch 13 → 14 not taken.
✓ Branch 13 → 15 taken 2456 times.
2456 assert(signedness && "Unsigned double types are forbidden");
203
1/2
✓ Branch 15 → 16 taken 2456 times.
✗ Branch 15 → 115 not taken.
2456 out << "d";
204 2456 break;
205 10752 case TY_INT:
206
3/4
✓ Branch 17 → 18 taken 10168 times.
✓ Branch 17 → 19 taken 584 times.
✓ Branch 20 → 21 taken 10752 times.
✗ Branch 20 → 115 not taken.
10752 out << (signedness ? "i" : "j");
207 10752 break;
208 2729 case TY_SHORT:
209
3/4
✓ Branch 22 → 23 taken 2715 times.
✓ Branch 22 → 24 taken 14 times.
✓ Branch 25 → 26 taken 2729 times.
✗ Branch 25 → 115 not taken.
2729 out << (signedness ? "s" : "t");
210 2729 break;
211 8193 case TY_LONG:
212
3/4
✓ Branch 27 → 28 taken 4049 times.
✓ Branch 27 → 29 taken 4144 times.
✓ Branch 30 → 31 taken 8193 times.
✗ Branch 30 → 115 not taken.
8193 out << (signedness ? "l" : "m");
213 8193 break;
214 2506 case TY_BYTE:
215
2/4
✗ Branch 32 → 33 not taken.
✓ Branch 32 → 34 taken 2506 times.
✓ Branch 35 → 36 taken 2506 times.
✗ Branch 35 → 115 not taken.
2506 out << (signedness ? "a" : "h");
216 2506 break;
217 7125 case TY_CHAR:
218
1/2
✓ Branch 37 → 38 taken 7125 times.
✗ Branch 37 → 115 not taken.
7125 out << "c";
219 7125 break;
220 10692 case TY_STRING:
221
1/2
✓ Branch 39 → 40 taken 10692 times.
✗ Branch 39 → 115 not taken.
10692 out << "PKc";
222 10692 break;
223 3373 case TY_BOOL:
224
1/2
✗ Branch 41 → 42 not taken.
✓ Branch 41 → 43 taken 3373 times.
3373 assert(!signedness && "Signed bool types are forbidden");
225
1/2
✓ Branch 43 → 44 taken 3373 times.
✗ Branch 43 → 115 not taken.
3373 out << "b";
226 3373 break;
227 36629 case TY_STRUCT: // fall-through
228 case TY_INTERFACE: {
229 36629 bool nestedType = false;
230
1/2
✓ Branch 45 → 46 taken 36629 times.
✗ Branch 45 → 101 not taken.
36629 mangleName(out, chainElement.subType, nestedType);
231
2/2
✓ Branch 47 → 48 taken 13055 times.
✓ Branch 47 → 57 taken 23574 times.
36629 if (!chainElement.templateTypes.empty()) {
232
1/2
✓ Branch 48 → 49 taken 13055 times.
✗ Branch 48 → 101 not taken.
13055 out << "I";
233
2/2
✓ Branch 55 → 51 taken 16470 times.
✓ Branch 55 → 56 taken 13055 times.
29525 for (const QualType &templateType : chainElement.templateTypes)
234
1/2
✓ Branch 52 → 53 taken 16470 times.
✗ Branch 52 → 100 not taken.
16470 mangleType(out, templateType);
235
1/2
✓ Branch 56 → 57 taken 13055 times.
✗ Branch 56 → 101 not taken.
13055 out << "E";
236 }
237
1/2
✗ Branch 57 → 58 not taken.
✓ Branch 57 → 59 taken 36629 times.
36629 if (nestedType)
238 out << "E";
239 36629 break;
240 }
241 case TY_ENUM: {
242 bool nestedType = false;
243 mangleName(out, chainElement.subType, nestedType);
244 if (nestedType)
245 out << "E";
246 break;
247 }
248 34 case TY_FUNCTION: {
249
3/4
✓ Branch 66 → 67 taken 2 times.
✓ Branch 66 → 68 taken 32 times.
✓ Branch 69 → 70 taken 34 times.
✗ Branch 69 → 115 not taken.
34 out << (chainElement.data.hasCaptures ? "PFC" : "PF");
250
2/2
✓ Branch 76 → 72 taken 94 times.
✓ Branch 76 → 77 taken 34 times.
128 for (const QualType &paramType : chainElement.paramTypes)
251
1/2
✓ Branch 73 → 74 taken 94 times.
✗ Branch 73 → 103 not taken.
94 mangleType(out, paramType);
252
1/2
✓ Branch 77 → 78 taken 34 times.
✗ Branch 77 → 115 not taken.
34 out << "E";
253 34 break;
254 }
255 65 case TY_PROCEDURE: {
256
3/4
✓ Branch 79 → 80 taken 2 times.
✓ Branch 79 → 81 taken 63 times.
✓ Branch 82 → 83 taken 65 times.
✗ Branch 82 → 115 not taken.
65 out << (chainElement.data.hasCaptures ? "PFCv" : "PFv");
257
2/2
✓ Branch 88 → 84 taken 84 times.
✓ Branch 88 → 89 taken 65 times.
149 for (size_t i = 1; i < chainElement.paramTypes.size(); i++)
258
2/4
✓ Branch 84 → 85 taken 84 times.
✗ Branch 84 → 115 not taken.
✓ Branch 85 → 86 taken 84 times.
✗ Branch 85 → 115 not taken.
84 mangleType(out, chainElement.paramTypes.at(i));
259
1/2
✓ Branch 89 → 90 taken 65 times.
✗ Branch 89 → 115 not taken.
65 out << "E";
260 65 break;
261 }
262 default: // GCOV_EXCL_LINE
263 const std::string message = "Type " + chainElement.getName(false, true, true) + " cannot be mangled"; // GCOV_EXCL_LINE
264 throw CompilerError(INTERNAL_ERROR, message); // GCOV_EXCL_LINE
265 }
266 95095 }
267
268 440 std::string NameMangling::mangleTypeInfoName(const StructBase *structBase) {
269
1/2
✓ Branch 2 → 3 taken 440 times.
✗ Branch 2 → 13 not taken.
440 std::stringstream out;
270
1/2
✓ Branch 3 → 4 taken 440 times.
✗ Branch 3 → 11 not taken.
440 out << "_ZTS";
271
2/4
✓ Branch 4 → 5 taken 440 times.
✗ Branch 4 → 11 not taken.
✓ Branch 5 → 6 taken 440 times.
✗ Branch 5 → 11 not taken.
440 mangleType(out, structBase->entry->getQualType());
272
1/2
✓ Branch 6 → 7 taken 440 times.
✗ Branch 6 → 11 not taken.
880 return out.str();
273 440 }
274
275
2/4
✓ Branch 3 → 4 taken 440 times.
✗ Branch 3 → 11 not taken.
✓ Branch 4 → 5 taken 440 times.
✗ Branch 4 → 9 not taken.
440 std::string NameMangling::mangleTypeInfoValue(const std::string &value) { return std::to_string(value.size()) + value; }
276
277 630 std::string NameMangling::mangleTypeInfo(const StructBase *structBase) {
278
1/2
✓ Branch 2 → 3 taken 630 times.
✗ Branch 2 → 13 not taken.
630 std::stringstream out;
279
1/2
✓ Branch 3 → 4 taken 630 times.
✗ Branch 3 → 11 not taken.
630 out << "_ZTI";
280
2/4
✓ Branch 4 → 5 taken 630 times.
✗ Branch 4 → 11 not taken.
✓ Branch 5 → 6 taken 630 times.
✗ Branch 5 → 11 not taken.
630 mangleType(out, structBase->entry->getQualType());
281
1/2
✓ Branch 6 → 7 taken 630 times.
✗ Branch 6 → 11 not taken.
1260 return out.str();
282 630 }
283
284 880 std::string NameMangling::mangleVTable(const StructBase *structBase) {
285
1/2
✓ Branch 2 → 3 taken 880 times.
✗ Branch 2 → 13 not taken.
880 std::stringstream out;
286
1/2
✓ Branch 3 → 4 taken 880 times.
✗ Branch 3 → 11 not taken.
880 out << "_ZTV";
287
2/4
✓ Branch 4 → 5 taken 880 times.
✗ Branch 4 → 11 not taken.
✓ Branch 5 → 6 taken 880 times.
✗ Branch 5 → 11 not taken.
880 mangleType(out, structBase->entry->getQualType());
288
1/2
✓ Branch 6 → 7 taken 880 times.
✗ Branch 6 → 11 not taken.
1760 return out.str();
289 880 }
290
291 389 std::string NameMangling::mangleVTable(const std::string &typeName) {
292
3/6
✓ Branch 3 → 4 taken 389 times.
✗ Branch 3 → 15 not taken.
✓ Branch 4 → 5 taken 389 times.
✗ Branch 4 → 13 not taken.
✓ Branch 5 → 6 taken 389 times.
✗ Branch 5 → 11 not taken.
389 return "_ZTV" + std::to_string(typeName.size()) + typeName;
293 }
294
295 } // namespace spice::compiler
296