Line | Branch | Exec | Source |
---|---|---|---|
1 | // Copyright (c) 2021-2024 ChilliBits. All rights reserved. | ||
2 | |||
3 | #include "StructBase.h" | ||
4 | |||
5 | #include <ast/ASTBuilder.h> | ||
6 | #include <ast/ASTNodes.h> | ||
7 | #include <typechecker/TypeMatcher.h> | ||
8 | #include <util/CommonUtil.h> | ||
9 | |||
10 | namespace spice::compiler { | ||
11 | |||
12 | /** | ||
13 | * Get a string representation of the current struct | ||
14 | * | ||
15 | * @return String representation as struct signature | ||
16 | */ | ||
17 | 2586 | std::string StructBase::getSignature() const { | |
18 | 2586 | QualTypeList templateSymbolTypes; | |
19 |
1/2✓ Branch 2 taken 2586 times.
✗ Branch 3 not taken.
|
2586 | templateSymbolTypes.reserve(templateTypes.size()); |
20 |
2/2✓ Branch 5 taken 2839 times.
✓ Branch 6 taken 2586 times.
|
5425 | for (const GenericType &genericType : templateTypes) { |
21 |
7/8✓ Branch 1 taken 2839 times.
✗ Branch 2 not taken.
✓ Branch 3 taken 1118 times.
✓ Branch 4 taken 1721 times.
✓ Branch 6 taken 772 times.
✓ Branch 7 taken 346 times.
✓ Branch 8 taken 772 times.
✓ Branch 9 taken 2067 times.
|
2839 | if (genericType.is(TY_GENERIC) && !typeMapping.empty()) { |
22 |
3/6✓ Branch 1 taken 772 times.
✗ Branch 2 not taken.
✓ Branch 4 taken 772 times.
✗ Branch 5 not taken.
✗ Branch 6 not taken.
✓ Branch 7 taken 772 times.
|
772 | assert(typeMapping.contains(genericType.getSubType())); |
23 |
3/6✓ Branch 1 taken 772 times.
✗ Branch 2 not taken.
✓ Branch 4 taken 772 times.
✗ Branch 5 not taken.
✓ Branch 7 taken 772 times.
✗ Branch 8 not taken.
|
772 | templateSymbolTypes.push_back(typeMapping.at(genericType.getSubType())); |
24 | } else { | ||
25 |
1/2✓ Branch 1 taken 2067 times.
✗ Branch 2 not taken.
|
2067 | templateSymbolTypes.push_back(genericType); |
26 | } | ||
27 | } | ||
28 | |||
29 |
1/2✓ Branch 1 taken 2586 times.
✗ Branch 2 not taken.
|
5172 | return getSignature(name, templateSymbolTypes); |
30 | 2586 | } | |
31 | |||
32 | /** | ||
33 | * Get the signature from the struct name and the concrete template types | ||
34 | * | ||
35 | * Example: | ||
36 | * Pair<int,double> | ||
37 | * | ||
38 | * @param name Struct name | ||
39 | * @param concreteTemplateTypes Concrete template types | ||
40 | * @return Signature | ||
41 | */ | ||
42 | 13103 | std::string StructBase::getSignature(const std::string &name, const QualTypeList &concreteTemplateTypes) { | |
43 | // Build template type string | ||
44 |
1/2✓ Branch 1 taken 13103 times.
✗ Branch 2 not taken.
|
13103 | std::stringstream templateTyStr; |
45 |
2/2✓ Branch 1 taken 5124 times.
✓ Branch 2 taken 7979 times.
|
13103 | if (!concreteTemplateTypes.empty()) { |
46 |
1/2✓ Branch 1 taken 5124 times.
✗ Branch 2 not taken.
|
5124 | templateTyStr << "<"; |
47 |
2/2✓ Branch 1 taken 6474 times.
✓ Branch 2 taken 5124 times.
|
11598 | for (size_t i = 0; i < concreteTemplateTypes.size(); i++) { |
48 |
2/2✓ Branch 0 taken 1350 times.
✓ Branch 1 taken 5124 times.
|
6474 | if (i > 0) |
49 |
1/2✓ Branch 1 taken 1350 times.
✗ Branch 2 not taken.
|
1350 | templateTyStr << ","; |
50 |
3/6✓ Branch 1 taken 6474 times.
✗ Branch 2 not taken.
✓ Branch 4 taken 6474 times.
✗ Branch 5 not taken.
✓ Branch 7 taken 6474 times.
✗ Branch 8 not taken.
|
6474 | templateTyStr << concreteTemplateTypes.at(i).getName(false, true); |
51 | } | ||
52 |
1/2✓ Branch 1 taken 5124 times.
✗ Branch 2 not taken.
|
5124 | templateTyStr << ">"; |
53 | } | ||
54 | |||
55 |
4/8✓ Branch 1 taken 13103 times.
✗ Branch 2 not taken.
✓ Branch 4 taken 13103 times.
✗ Branch 5 not taken.
✓ Branch 7 taken 13103 times.
✗ Branch 8 not taken.
✓ Branch 10 taken 13103 times.
✗ Branch 11 not taken.
|
52412 | return CommonUtil::getLastFragment(name, SCOPE_ACCESS_TOKEN) + templateTyStr.str(); |
56 | 13103 | } | |
57 | |||
58 | /** | ||
59 | * Checks if a struct contains template types. | ||
60 | * This would imply that the struct is not substantiated by its generic types yet. | ||
61 | * | ||
62 | * @return Substantiated generics or not | ||
63 | */ | ||
64 | 6679 | bool StructBase::hasSubstantiatedGenerics() const { | |
65 | 5922 | const auto lambda = [](const GenericType &genericType) { return genericType.hasAnyGenericParts(); }; | |
66 |
1/2✓ Branch 1 taken 6679 times.
✗ Branch 2 not taken.
|
13358 | return std::ranges::none_of(templateTypes, lambda); |
67 | } | ||
68 | |||
69 | /** | ||
70 | * Checks if a struct has generic types present. | ||
71 | * This would imply that the struct is not fully substantiated yet. | ||
72 | * | ||
73 | * @return Fully substantiated or not | ||
74 | */ | ||
75 | 6679 | bool StructBase::isFullySubstantiated() const { return hasSubstantiatedGenerics(); } | |
76 | |||
77 | /** | ||
78 | * Retrieve the template types as vector of symbol types | ||
79 | * | ||
80 | * @return Template types as vector of symbol types | ||
81 | */ | ||
82 | 416 | QualTypeList StructBase::getTemplateTypes() const { | |
83 | 416 | QualTypeList templateSymbolTypes; | |
84 |
2/2✓ Branch 5 taken 553 times.
✓ Branch 6 taken 416 times.
|
969 | for (const GenericType &genericTemplateType : templateTypes) |
85 |
1/2✓ Branch 1 taken 553 times.
✗ Branch 2 not taken.
|
553 | templateSymbolTypes.push_back(genericTemplateType); |
86 | 416 | return templateSymbolTypes; | |
87 | ✗ | } | |
88 | |||
89 | /** | ||
90 | * Retrieve the declaration code location of this struct | ||
91 | * | ||
92 | * @return Declaration code location | ||
93 | */ | ||
94 | 444 | const CodeLoc &StructBase::getDeclCodeLoc() const { return declNode->codeLoc; } | |
95 | |||
96 | /** | ||
97 | * Returns, if this struct is a substantiation of a generic one. | ||
98 | * | ||
99 | * @return Generic substantiation or not | ||
100 | */ | ||
101 | 2195 | bool StructBase::isGenericSubstantiation() const { return genericPreset != nullptr; } | |
102 | |||
103 | } // namespace spice::compiler | ||
104 |