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 32107 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 32107 times.
32107 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 32107 times.
32107 if (!spiceFunc.mangleFunctionName)
30 return spiceFunc.name;
31
32
1/2
✓ Branch 9 → 10 taken 32107 times.
✗ Branch 9 → 104 not taken.
32107 std::stringstream mangledName;
33
1/2
✓ Branch 10 → 11 taken 32107 times.
✗ Branch 10 → 102 not taken.
32107 mangledName << "_Z";
34
35 // This type
36
2/2
✓ Branch 14 → 15 taken 19405 times.
✓ Branch 14 → 17 taken 12702 times.
32107 if (spiceFunc.isMethod()) {
37
1/2
✓ Branch 15 → 16 taken 19405 times.
✗ Branch 15 → 102 not taken.
19405 mangledName << "N";
38
1/2
✓ Branch 16 → 17 taken 19405 times.
✗ Branch 16 → 102 not taken.
19405 mangleType(mangledName, spiceFunc.thisType);
39 }
40
41 // Function name
42
1/2
✓ Branch 17 → 18 taken 32107 times.
✗ Branch 17 → 102 not taken.
32107 const std::string name = spiceFunc.name + spiceFunc.mangleSuffix;
43
2/4
✓ Branch 19 → 20 taken 32107 times.
✗ Branch 19 → 100 not taken.
✓ Branch 20 → 21 taken 32107 times.
✗ Branch 20 → 100 not taken.
32107 mangledName << name.length() << name;
44
45 // Template types
46
1/2
✓ Branch 22 → 23 taken 32107 times.
✗ Branch 22 → 100 not taken.
32107 bool isSelfGeneric = !spiceFunc.templateTypes.empty();
47
2/2
✓ Branch 25 → 26 taken 19405 times.
✓ Branch 25 → 30 taken 12702 times.
32107 if (spiceFunc.isMethod())
48
1/2
✓ Branch 27 → 28 taken 19405 times.
✗ Branch 27 → 100 not taken.
19405 isSelfGeneric = spiceFunc.templateTypes.size() > spiceFunc.thisType.getTemplateTypes().size();
49
2/2
✓ Branch 30 → 31 taken 3861 times.
✓ Branch 30 → 57 taken 28246 times.
32107 if (isSelfGeneric) {
50
1/2
✓ Branch 31 → 32 taken 3861 times.
✗ Branch 31 → 100 not taken.
3861 mangledName << "I";
51 // Template types themselves
52
2/2
✓ Branch 44 → 34 taken 6531 times.
✓ Branch 44 → 45 taken 3861 times.
10392 for (const GenericType &genericTemplateType : spiceFunc.templateTypes) {
53
3/6
✓ Branch 35 → 36 taken 6531 times.
✗ Branch 35 → 93 not taken.
✓ Branch 36 → 37 taken 6531 times.
✗ Branch 36 → 93 not taken.
✗ Branch 37 → 38 not taken.
✓ Branch 37 → 39 taken 6531 times.
6531 assert(spiceFunc.typeMapping.contains(genericTemplateType.getSubType()));
54
2/4
✓ Branch 39 → 40 taken 6531 times.
✗ Branch 39 → 93 not taken.
✓ Branch 40 → 41 taken 6531 times.
✗ Branch 40 → 93 not taken.
6531 const QualType &actualType = spiceFunc.typeMapping.at(genericTemplateType.getSubType());
55
1/2
✓ Branch 41 → 42 taken 6531 times.
✗ Branch 41 → 93 not taken.
6531 mangleType(mangledName, actualType);
56 }
57
1/2
✓ Branch 45 → 46 taken 3861 times.
✗ Branch 45 → 100 not taken.
3861 mangledName << "E";
58
59 // Insert second end marker to end the nested type
60
2/2
✓ Branch 49 → 50 taken 600 times.
✓ Branch 49 → 51 taken 3261 times.
3861 if (spiceFunc.isMethod())
61
1/2
✓ Branch 50 → 51 taken 600 times.
✗ Branch 50 → 100 not taken.
600 mangledName << "E";
62
63 // Return type
64
2/2
✓ Branch 54 → 55 taken 1186 times.
✓ Branch 54 → 56 taken 2675 times.
3861 if (spiceFunc.isFunction())
65
1/2
✓ Branch 55 → 62 taken 1186 times.
✗ Branch 55 → 100 not taken.
1186 mangleType(mangledName, spiceFunc.returnType);
66 else
67
1/2
✓ Branch 56 → 62 taken 2675 times.
✗ Branch 56 → 100 not taken.
2675 mangledName << "v";
68
2/2
✓ Branch 60 → 61 taken 18805 times.
✓ Branch 60 → 62 taken 9441 times.
28246 } else if (spiceFunc.isMethod()) {
69
1/2
✓ Branch 61 → 62 taken 18805 times.
✗ Branch 61 → 100 not taken.
18805 mangledName << "E";
70 }
71
72 // Parameter types
73
2/2
✓ Branch 70 → 64 taken 35656 times.
✓ Branch 70 → 71 taken 32107 times.
67763 for (const auto &[qualType, isOptional] : spiceFunc.paramList) {
74
1/2
✗ Branch 65 → 66 not taken.
✓ Branch 65 → 67 taken 35656 times.
35656 assert(!isOptional);
75
1/2
✓ Branch 67 → 68 taken 35656 times.
✗ Branch 67 → 94 not taken.
35656 mangleType(mangledName, qualType);
76 }
77
2/2
✓ Branch 72 → 73 taken 10272 times.
✓ Branch 72 → 74 taken 21835 times.
32107 if (spiceFunc.paramList.empty())
78
1/2
✓ Branch 73 → 74 taken 10272 times.
✗ Branch 73 → 100 not taken.
10272 mangledName << "v";
79
80 #ifndef NDEBUG
81 32107 const TypeMapping &typeMapping = spiceFunc.typeMapping;
82
2/4
✓ Branch 74 → 75 taken 32107 times.
✗ Branch 74 → 96 not taken.
✓ Branch 75 → 76 taken 32107 times.
✗ Branch 75 → 95 not taken.
32107 const bool returnTypeIsFctOrProc = spiceFunc.returnType.getBase().isOneOf({TY_FUNCTION, TY_PROCEDURE});
83
2/4
✓ Branch 2 → 3 taken 35617 times.
✗ Branch 2 → 8 not taken.
✓ Branch 3 → 4 taken 35617 times.
✗ Branch 3 → 7 not taken.
35617 const auto paramPredicate = [](const Param &p) { return p.qualType.getBase().isOneOf({TY_FUNCTION, TY_PROCEDURE}); };
84
1/2
✓ Branch 76 → 77 taken 32107 times.
✗ Branch 76 → 100 not taken.
32107 const bool paramTypeIsFctOrProc = std::ranges::any_of(spiceFunc.paramList, paramPredicate);
85 12498 const auto templateTypePredicate = [&](const GenericType &t) {
86
2/2
✓ Branch 3 → 4 taken 12494 times.
✓ Branch 3 → 14 taken 4 times.
12498 if (t.is(TY_GENERIC)) {
87
1/2
✗ Branch 6 → 7 not taken.
✓ Branch 6 → 8 taken 12494 times.
12494 assert(typeMapping.contains(t.getSubType()));
88
4/8
✓ Branch 8 → 9 taken 12494 times.
✗ Branch 8 → 20 not taken.
✓ Branch 9 → 10 taken 12494 times.
✗ Branch 9 → 20 not taken.
✓ Branch 10 → 11 taken 12494 times.
✗ Branch 10 → 20 not taken.
✓ Branch 11 → 12 taken 12494 times.
✗ Branch 11 → 19 not taken.
12494 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 32107 };
92
1/2
✓ Branch 77 → 78 taken 32107 times.
✗ Branch 77 → 100 not taken.
32107 const bool templateTypeIsFctOrProc = std::ranges::any_of(spiceFunc.templateTypes, templateTypePredicate);
93
4/6
✓ Branch 78 → 79 taken 32107 times.
✗ Branch 78 → 87 not taken.
✓ Branch 79 → 80 taken 32048 times.
✓ Branch 79 → 87 taken 59 times.
✓ Branch 80 → 81 taken 32048 times.
✗ Branch 80 → 87 not taken.
32107 if (!returnTypeIsFctOrProc && !paramTypeIsFctOrProc && !templateTypeIsFctOrProc)
94
3/6
✓ Branch 81 → 82 taken 32048 times.
✗ Branch 81 → 99 not taken.
✓ Branch 82 → 83 taken 32048 times.
✗ Branch 82 → 97 not taken.
✗ Branch 83 → 84 not taken.
✓ Branch 83 → 85 taken 32048 times.
32048 assert(CommonUtil::isValidMangledName(mangledName.str()));
95 #endif
96
97
1/2
✓ Branch 87 → 88 taken 32107 times.
✗ Branch 87 → 100 not taken.
32107 return mangledName.str();
98 32107 }
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 1888 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 257 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 32529 void NameMangling::mangleName(std::stringstream &out, const std::string &name, bool &nestedType) {
127 32529 std::vector<std::string> fragments;
128
1/2
✓ Branch 2 → 3 taken 32529 times.
✗ Branch 2 → 51 not taken.
32529 std::istringstream ss(name);
129 32529 std::string token;
130
131
4/6
✓ Branch 16 → 17 taken 65058 times.
✗ Branch 16 → 47 not taken.
✓ Branch 17 → 18 taken 65058 times.
✗ Branch 17 → 47 not taken.
✓ Branch 18 → 5 taken 32529 times.
✓ Branch 18 → 19 taken 32529 times.
65058 while (std::getline(ss, token, ':')) {
132
1/2
✓ Branch 5 → 6 taken 32529 times.
✗ Branch 5 → 42 not taken.
32529 std::istringstream subStream(token);
133 32529 std::string subToken;
134
4/6
✓ Branch 10 → 11 taken 65058 times.
✗ Branch 10 → 38 not taken.
✓ Branch 11 → 12 taken 65058 times.
✗ Branch 11 → 38 not taken.
✓ Branch 12 → 8 taken 32529 times.
✓ Branch 12 → 13 taken 32529 times.
65058 while (std::getline(subStream, subToken, '/')) {
135
1/2
✓ Branch 8 → 9 taken 32529 times.
✗ Branch 8 → 38 not taken.
32529 fragments.push_back(subToken);
136 }
137 32529 }
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 32529 times.
32529 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 32529 times.
✓ Branch 33 → 34 taken 32529 times.
65058 for (const std::string &fragment : fragments) {
147 32529 int fragmentLength = static_cast<int>(fragment.length());
148
2/4
✓ Branch 28 → 29 taken 32529 times.
✗ Branch 28 → 43 not taken.
✓ Branch 29 → 30 taken 32529 times.
✗ Branch 29 → 43 not taken.
32529 out << std::to_string(fragmentLength) << fragment;
149 }
150 32529 }
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 77609 void NameMangling::mangleType(std::stringstream &out, const QualType &qualType) { // NOLINT(*-no-recursion)
161 77609 const Type *type = qualType.getType();
162
1/2
✗ Branch 4 → 5 not taken.
✓ Branch 4 → 6 taken 77609 times.
77609 assert(!qualType.hasAnyGenericParts());
163
164 // Unwrap qualType chain
165
1/2
✗ Branch 7 → 8 not taken.
✓ Branch 7 → 9 taken 77609 times.
77609 assert(!type->typeChain.empty());
166
2/2
✓ Branch 14 → 11 taken 9145 times.
✓ Branch 14 → 15 taken 77609 times.
86754 for (size_t i = type->typeChain.size() - 1; i >= 1; i--)
167 9145 mangleTypeChainElement(out, type->typeChain.at(i), false);
168
169 // Qualifiers
170
1/2
✗ Branch 17 → 18 not taken.
✓ Branch 17 → 19 taken 77609 times.
77609 assert(qualType.getQualifiers().isSigned == !qualType.getQualifiers().isUnsigned);
171 77609 const bool signedness = qualType.getQualifiers().isSigned;
172
6/6
✓ Branch 21 → 22 taken 13208 times.
✓ Branch 21 → 25 taken 64401 times.
✓ Branch 23 → 24 taken 5046 times.
✓ Branch 23 → 25 taken 8162 times.
✓ Branch 26 → 27 taken 5046 times.
✓ Branch 26 → 28 taken 72563 times.
77609 if (qualType.getQualifiers().isConst && type->typeChain.size() > 1)
173 5046 out << "K";
174
175 // Base chain element
176 77609 mangleTypeChainElement(out, type->typeChain.front(), signedness);
177 77609 }
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 86754 void NameMangling::mangleTypeChainElement(std::stringstream &out, const TypeChainElement &chainElement, bool signedness) {
188
14/16
✓ Branch 2 → 3 taken 2436 times.
✓ Branch 2 → 5 taken 124 times.
✓ Branch 2 → 11 taken 6585 times.
✓ Branch 2 → 13 taken 2446 times.
✓ Branch 2 → 17 taken 9301 times.
✓ Branch 2 → 22 taken 2722 times.
✓ Branch 2 → 27 taken 7883 times.
✓ Branch 2 → 32 taken 2344 times.
✓ Branch 2 → 37 taken 6842 times.
✓ Branch 2 → 39 taken 10373 times.
✓ Branch 2 → 41 taken 3070 times.
✓ Branch 2 → 45 taken 32529 times.
✗ Branch 2 → 61 not taken.
✓ Branch 2 → 66 taken 34 times.
✓ Branch 2 → 79 taken 65 times.
✗ Branch 2 → 91 not taken.
86754 switch (chainElement.superType) {
189 2436 case TY_PTR:
190
1/2
✓ Branch 3 → 4 taken 2436 times.
✗ Branch 3 → 115 not taken.
2436 out << "P";
191 2436 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 6585 case TY_REF:
199
1/2
✓ Branch 11 → 12 taken 6585 times.
✗ Branch 11 → 115 not taken.
6585 out << "R";
200 6585 break;
201 2446 case TY_DOUBLE:
202
1/2
✗ Branch 13 → 14 not taken.
✓ Branch 13 → 15 taken 2446 times.
2446 assert(signedness && "Unsigned double types are forbidden");
203
1/2
✓ Branch 15 → 16 taken 2446 times.
✗ Branch 15 → 115 not taken.
2446 out << "d";
204 2446 break;
205 9301 case TY_INT:
206
3/4
✓ Branch 17 → 18 taken 8729 times.
✓ Branch 17 → 19 taken 572 times.
✓ Branch 20 → 21 taken 9301 times.
✗ Branch 20 → 115 not taken.
9301 out << (signedness ? "i" : "j");
207 9301 break;
208 2722 case TY_SHORT:
209
3/4
✓ Branch 22 → 23 taken 2708 times.
✓ Branch 22 → 24 taken 14 times.
✓ Branch 25 → 26 taken 2722 times.
✗ Branch 25 → 115 not taken.
2722 out << (signedness ? "s" : "t");
210 2722 break;
211 7883 case TY_LONG:
212
3/4
✓ Branch 27 → 28 taken 4017 times.
✓ Branch 27 → 29 taken 3866 times.
✓ Branch 30 → 31 taken 7883 times.
✗ Branch 30 → 115 not taken.
7883 out << (signedness ? "l" : "m");
213 7883 break;
214 2344 case TY_BYTE:
215
2/4
✗ Branch 32 → 33 not taken.
✓ Branch 32 → 34 taken 2344 times.
✓ Branch 35 → 36 taken 2344 times.
✗ Branch 35 → 115 not taken.
2344 out << (signedness ? "a" : "h");
216 2344 break;
217 6842 case TY_CHAR:
218
1/2
✓ Branch 37 → 38 taken 6842 times.
✗ Branch 37 → 115 not taken.
6842 out << "c";
219 6842 break;
220 10373 case TY_STRING:
221
1/2
✓ Branch 39 → 40 taken 10373 times.
✗ Branch 39 → 115 not taken.
10373 out << "PKc";
222 10373 break;
223 3070 case TY_BOOL:
224
1/2
✗ Branch 41 → 42 not taken.
✓ Branch 41 → 43 taken 3070 times.
3070 assert(!signedness && "Signed bool types are forbidden");
225
1/2
✓ Branch 43 → 44 taken 3070 times.
✗ Branch 43 → 115 not taken.
3070 out << "b";
226 3070 break;
227 32529 case TY_STRUCT: // fall-through
228 case TY_INTERFACE: {
229 32529 bool nestedType = false;
230
1/2
✓ Branch 45 → 46 taken 32529 times.
✗ Branch 45 → 101 not taken.
32529 mangleName(out, chainElement.subType, nestedType);
231
2/2
✓ Branch 47 → 48 taken 10071 times.
✓ Branch 47 → 57 taken 22458 times.
32529 if (!chainElement.templateTypes.empty()) {
232
1/2
✓ Branch 48 → 49 taken 10071 times.
✗ Branch 48 → 101 not taken.
10071 out << "I";
233
2/2
✓ Branch 55 → 51 taken 12911 times.
✓ Branch 55 → 56 taken 10071 times.
22982 for (const QualType &templateType : chainElement.templateTypes)
234
1/2
✓ Branch 52 → 53 taken 12911 times.
✗ Branch 52 → 100 not taken.
12911 mangleType(out, templateType);
235
1/2
✓ Branch 56 → 57 taken 10071 times.
✗ Branch 56 → 101 not taken.
10071 out << "E";
236 }
237
1/2
✗ Branch 57 → 58 not taken.
✓ Branch 57 → 59 taken 32529 times.
32529 if (nestedType)
238 out << "E";
239 32529 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 86754 }
267
268 394 std::string NameMangling::mangleTypeInfoName(const StructBase *structBase) {
269
1/2
✓ Branch 2 → 3 taken 394 times.
✗ Branch 2 → 13 not taken.
394 std::stringstream out;
270
1/2
✓ Branch 3 → 4 taken 394 times.
✗ Branch 3 → 11 not taken.
394 out << "_ZTS";
271
2/4
✓ Branch 4 → 5 taken 394 times.
✗ Branch 4 → 11 not taken.
✓ Branch 5 → 6 taken 394 times.
✗ Branch 5 → 11 not taken.
394 mangleType(out, structBase->entry->getQualType());
272
1/2
✓ Branch 6 → 7 taken 394 times.
✗ Branch 6 → 11 not taken.
788 return out.str();
273 394 }
274
275
2/4
✓ Branch 3 → 4 taken 394 times.
✗ Branch 3 → 11 not taken.
✓ Branch 4 → 5 taken 394 times.
✗ Branch 4 → 9 not taken.
394 std::string NameMangling::mangleTypeInfoValue(const std::string &value) { return std::to_string(value.size()) + value; }
276
277 560 std::string NameMangling::mangleTypeInfo(const StructBase *structBase) {
278
1/2
✓ Branch 2 → 3 taken 560 times.
✗ Branch 2 → 13 not taken.
560 std::stringstream out;
279
1/2
✓ Branch 3 → 4 taken 560 times.
✗ Branch 3 → 11 not taken.
560 out << "_ZTI";
280
2/4
✓ Branch 4 → 5 taken 560 times.
✗ Branch 4 → 11 not taken.
✓ Branch 5 → 6 taken 560 times.
✗ Branch 5 → 11 not taken.
560 mangleType(out, structBase->entry->getQualType());
281
1/2
✓ Branch 6 → 7 taken 560 times.
✗ Branch 6 → 11 not taken.
1120 return out.str();
282 560 }
283
284 788 std::string NameMangling::mangleVTable(const StructBase *structBase) {
285
1/2
✓ Branch 2 → 3 taken 788 times.
✗ Branch 2 → 13 not taken.
788 std::stringstream out;
286
1/2
✓ Branch 3 → 4 taken 788 times.
✗ Branch 3 → 11 not taken.
788 out << "_ZTV";
287
2/4
✓ Branch 4 → 5 taken 788 times.
✗ Branch 4 → 11 not taken.
✓ Branch 5 → 6 taken 788 times.
✗ Branch 5 → 11 not taken.
788 mangleType(out, structBase->entry->getQualType());
288
1/2
✓ Branch 6 → 7 taken 788 times.
✗ Branch 6 → 11 not taken.
1576 return out.str();
289 788 }
290
291 344 std::string NameMangling::mangleVTable(const std::string &typeName) {
292
3/6
✓ Branch 3 → 4 taken 344 times.
✗ Branch 3 → 15 not taken.
✓ Branch 4 → 5 taken 344 times.
✗ Branch 4 → 13 not taken.
✓ Branch 5 → 6 taken 344 times.
✗ Branch 5 → 11 not taken.
344 return "_ZTV" + std::to_string(typeName.size()) + typeName;
293 }
294
295 } // namespace spice::compiler
296