src/symboltablebuilder/TypeChain.cpp
| Line | Branch | Exec | Source |
|---|---|---|---|
| 1 | // Copyright (c) 2021-2026 ChilliBits. All rights reserved. | ||
| 2 | |||
| 3 | #include "TypeChain.h" | ||
| 4 | |||
| 5 | #include <exception/CompilerError.h> | ||
| 6 | |||
| 7 | namespace spice::compiler { | ||
| 8 | |||
| 9 | 4990975 | bool operator==(const TypeChainElement &lhs, const TypeChainElement &rhs) { | |
| 10 | // Check super type | ||
| 11 |
2/2✓ Branch 2 → 3 taken 51415 times.
✓ Branch 2 → 4 taken 4939560 times.
|
4990975 | if (lhs.superType != rhs.superType) |
| 12 | 51415 | return false; | |
| 13 | |||
| 14 | // Check data | ||
| 15 |
7/7✓ Branch 4 → 5 taken 542 times.
✓ Branch 4 → 6 taken 1117635 times.
✓ Branch 4 → 16 taken 33431 times.
✓ Branch 4 → 17 taken 101 times.
✓ Branch 4 → 26 taken 142198 times.
✓ Branch 4 → 40 taken 395668 times.
✓ Branch 4 → 41 taken 3249985 times.
|
4939560 | switch (lhs.superType) { |
| 16 | 542 | case TY_ARRAY: | |
| 17 | 542 | return lhs.data.arraySize == rhs.data.arraySize; | |
| 18 | 1117635 | case TY_STRUCT: | |
| 19 |
2/4✓ Branch 6 → 7 taken 1117635 times.
✗ Branch 6 → 9 not taken.
✓ Branch 7 → 8 taken 1117635 times.
✗ Branch 7 → 9 not taken.
|
1117635 | assert(lhs.data.bodyScope != nullptr && rhs.data.bodyScope != nullptr); |
| 20 |
4/4✓ Branch 10 → 11 taken 1114724 times.
✓ Branch 10 → 14 taken 2911 times.
✓ Branch 12 → 13 taken 1114690 times.
✓ Branch 12 → 14 taken 34 times.
|
1117635 | return lhs.typeId == rhs.typeId && lhs.templateTypes == rhs.templateTypes; |
| 21 | 33431 | case TY_INTERFACE: | |
| 22 | 33431 | return lhs.typeId == rhs.typeId; | |
| 23 | 101 | case TY_ENUM: | |
| 24 |
2/4✓ Branch 17 → 18 taken 101 times.
✗ Branch 17 → 20 not taken.
✓ Branch 18 → 19 taken 101 times.
✗ Branch 18 → 20 not taken.
|
101 | assert(lhs.data.bodyScope != nullptr && rhs.data.bodyScope != nullptr); |
| 25 |
2/4✓ Branch 21 → 22 taken 101 times.
✗ Branch 21 → 24 not taken.
✓ Branch 22 → 23 taken 101 times.
✗ Branch 22 → 24 not taken.
|
101 | return lhs.typeId == rhs.typeId && lhs.data.bodyScope == rhs.data.bodyScope; |
| 26 | 142198 | case TY_FUNCTION: // fall-through | |
| 27 | case TY_PROCEDURE: | ||
| 28 |
1/2✗ Branch 28 → 29 not taken.
✓ Branch 28 → 30 taken 142198 times.
|
142198 | if (lhs.paramTypes.size() != rhs.paramTypes.size()) |
| 29 | ✗ | return false; | |
| 30 |
2/2✓ Branch 38 → 31 taken 189736 times.
✓ Branch 38 → 39 taken 142196 times.
|
331932 | for (size_t i = 0; i < lhs.paramTypes.size(); i++) |
| 31 |
2/2✓ Branch 34 → 35 taken 2 times.
✓ Branch 34 → 36 taken 189734 times.
|
189736 | if (lhs.paramTypes.at(i) != rhs.paramTypes.at(i)) |
| 32 | 2 | return false; | |
| 33 | 142196 | return true; | |
| 34 | 395668 | case TY_GENERIC: | |
| 35 | 395668 | return lhs.subType == rhs.subType; | |
| 36 | 3249985 | default: | |
| 37 | 3249985 | return true; | |
| 38 | } | ||
| 39 | } | ||
| 40 | |||
| 41 | 185516 | bool operator!=(const TypeChainElement &lhs, const TypeChainElement &rhs) { return !(lhs == rhs); } | |
| 42 | |||
| 43 | 1160139 | void TypeChainElement::getName(std::stringstream &name, bool withSize, bool ignorePublic, bool withAliases) const { | |
| 44 |
19/20✓ Branch 2 → 3 taken 111982 times.
✓ Branch 2 → 4 taken 124883 times.
✓ Branch 2 → 6 taken 558 times.
✓ Branch 2 → 20 taken 6891 times.
✓ Branch 2 → 22 taken 91378 times.
✓ Branch 2 → 24 taken 8592 times.
✓ Branch 2 → 26 taken 88018 times.
✓ Branch 2 → 28 taken 28048 times.
✓ Branch 2 → 30 taken 39448 times.
✓ Branch 2 → 32 taken 47047 times.
✓ Branch 2 → 37 taken 65193 times.
✓ Branch 2 → 39 taken 229511 times.
✓ Branch 2 → 53 taken 181 times.
✓ Branch 2 → 57 taken 182477 times.
✓ Branch 2 → 59 taken 279 times.
✓ Branch 2 → 61 taken 57706 times.
✓ Branch 2 → 81 taken 41192 times.
✓ Branch 2 → 95 taken 2499 times.
✓ Branch 2 → 97 taken 34256 times.
✗ Branch 2 → 99 not taken.
|
1160139 | switch (superType) { |
| 45 | 111982 | case TY_PTR: | |
| 46 | 111982 | name << "*"; | |
| 47 | 111982 | break; | |
| 48 | 124883 | case TY_REF: | |
| 49 | 124883 | name << "&"; | |
| 50 | 124883 | break; | |
| 51 | 558 | case TY_ARRAY: | |
| 52 |
9/14✓ Branch 7 → 8 taken 271 times.
✓ Branch 7 → 10 taken 287 times.
✓ Branch 8 → 9 taken 124 times.
✓ Branch 8 → 10 taken 147 times.
✓ Branch 12 → 13 taken 434 times.
✗ Branch 12 → 111 not taken.
✓ Branch 13 → 14 taken 558 times.
✗ Branch 13 → 109 not taken.
✓ Branch 14 → 15 taken 558 times.
✗ Branch 14 → 109 not taken.
✓ Branch 16 → 17 taken 434 times.
✓ Branch 16 → 19 taken 124 times.
✗ Branch 111 → 112 not taken.
✗ Branch 111 → 114 not taken.
|
992 | name << "[" << (withSize && data.arraySize != ARRAY_SIZE_UNKNOWN ? std::to_string(data.arraySize) : "") << "]"; |
| 53 | 558 | break; | |
| 54 | 6891 | case TY_DOUBLE: | |
| 55 | 6891 | name << "double"; | |
| 56 | 6891 | break; | |
| 57 | 91378 | case TY_INT: | |
| 58 | 91378 | name << "int"; | |
| 59 | 91378 | break; | |
| 60 | 8592 | case TY_SHORT: | |
| 61 | 8592 | name << "short"; | |
| 62 | 8592 | break; | |
| 63 | 88018 | case TY_LONG: | |
| 64 | 88018 | name << "long"; | |
| 65 | 88018 | break; | |
| 66 | 28048 | case TY_BYTE: | |
| 67 | 28048 | name << "byte"; | |
| 68 | 28048 | break; | |
| 69 | 39448 | case TY_CHAR: | |
| 70 | 39448 | name << "char"; | |
| 71 | 39448 | break; | |
| 72 | 47047 | case TY_STRING: | |
| 73 |
2/2✓ Branch 32 → 33 taken 29558 times.
✓ Branch 32 → 34 taken 17489 times.
|
47047 | name << (withAliases ? "string" : "const char*"); |
| 74 | 47047 | break; | |
| 75 | 65193 | case TY_BOOL: | |
| 76 | 65193 | name << "bool"; | |
| 77 | 65193 | break; | |
| 78 | 229511 | case TY_STRUCT: // fall-through | |
| 79 | case TY_INTERFACE: | ||
| 80 | 229511 | name << subType; | |
| 81 |
2/2✓ Branch 41 → 42 taken 141394 times.
✓ Branch 41 → 52 taken 88117 times.
|
229511 | if (!templateTypes.empty()) { |
| 82 | 141394 | name << "<"; | |
| 83 |
2/2✓ Branch 50 → 44 taken 190653 times.
✓ Branch 50 → 51 taken 141394 times.
|
332047 | for (size_t i = 0; i < templateTypes.size(); i++) { |
| 84 |
2/2✓ Branch 44 → 45 taken 49259 times.
✓ Branch 44 → 46 taken 141394 times.
|
190653 | if (i > 0) |
| 85 | 49259 | name << ","; | |
| 86 | 190653 | templateTypes.at(i).getName(name, withSize, ignorePublic); | |
| 87 | } | ||
| 88 | 141394 | name << ">"; | |
| 89 | } | ||
| 90 | 229511 | break; | |
| 91 | 181 | case TY_ENUM: | |
| 92 | 181 | name << "enum(" << subType << ")"; | |
| 93 | 181 | break; | |
| 94 | 182477 | case TY_GENERIC: // fall-through | |
| 95 | case TY_ALIAS: | ||
| 96 | 182477 | name << subType; | |
| 97 | 182477 | break; | |
| 98 | 279 | case TY_DYN: | |
| 99 | 279 | name << "dyn"; | |
| 100 | 279 | break; | |
| 101 | 57706 | case TY_FUNCTION: { | |
| 102 | 57706 | name << "f"; | |
| 103 |
2/2✓ Branch 62 → 63 taken 12 times.
✓ Branch 62 → 64 taken 57694 times.
|
57706 | if (data.hasCaptures) |
| 104 | 12 | name << "[]"; | |
| 105 |
2/2✓ Branch 65 → 66 taken 57427 times.
✓ Branch 65 → 70 taken 279 times.
|
57706 | if (!paramTypes.empty()) { |
| 106 | 57427 | name << "<"; | |
| 107 | 57427 | paramTypes.front().getName(name, true, ignorePublic); | |
| 108 | 57427 | name << ">"; | |
| 109 | } | ||
| 110 | 57706 | name << "("; | |
| 111 |
2/2✓ Branch 78 → 72 taken 48865 times.
✓ Branch 78 → 79 taken 57706 times.
|
106571 | for (size_t i = 1; i < paramTypes.size(); i++) { |
| 112 |
2/2✓ Branch 72 → 73 taken 17779 times.
✓ Branch 72 → 74 taken 31086 times.
|
48865 | if (i > 1) |
| 113 | 17779 | name << ","; | |
| 114 | 48865 | paramTypes.at(i).getName(name, true, ignorePublic); | |
| 115 | } | ||
| 116 | 57706 | name << ")"; | |
| 117 | 57706 | break; | |
| 118 | } | ||
| 119 | 41192 | case TY_PROCEDURE: { | |
| 120 | 41192 | name << "p"; | |
| 121 |
2/2✓ Branch 82 → 83 taken 26 times.
✓ Branch 82 → 84 taken 41166 times.
|
41192 | if (data.hasCaptures) |
| 122 | 26 | name << "[]"; | |
| 123 | 41192 | name << "("; | |
| 124 |
2/2✓ Branch 92 → 86 taken 42720 times.
✓ Branch 92 → 93 taken 41192 times.
|
83912 | for (size_t i = 1; i < paramTypes.size(); i++) { |
| 125 |
2/2✓ Branch 86 → 87 taken 12577 times.
✓ Branch 86 → 88 taken 30143 times.
|
42720 | if (i > 1) |
| 126 | 12577 | name << ","; | |
| 127 | 42720 | paramTypes.at(i).getName(name, true, ignorePublic); | |
| 128 | } | ||
| 129 | 41192 | name << ")"; | |
| 130 | 41192 | break; | |
| 131 | } | ||
| 132 | 2499 | case TY_IMPORT: | |
| 133 | 2499 | name << "import"; | |
| 134 | 2499 | break; | |
| 135 | − | case TY_INVALID: // GCOV_EXCL_LINE | |
| 136 | − | name << "invalid"; // GCOV_EXCL_LINE | |
| 137 | − | break; // GCOV_EXCL_LINE | |
| 138 | − | default: // GCOV_EXCL_LINE | |
| 139 | − | throw CompilerError(INTERNAL_ERROR, "Could not get name of this type chain element"); // GCOV_EXCL_LINE | |
| 140 | } | ||
| 141 | 1160139 | } | |
| 142 | |||
| 143 | /** | ||
| 144 | * Return the type name as string | ||
| 145 | * | ||
| 146 | * @param withSize Also encode array sizes | ||
| 147 | * @param ignorePublic Ignore public qualifier | ||
| 148 | * @param withAliases Print aliases as is and not decompose them | ||
| 149 | * @return Name as string | ||
| 150 | */ | ||
| 151 | 1160139 | std::string TypeChainElement::getName(bool withSize, bool ignorePublic, bool withAliases) const { | |
| 152 |
1/2✓ Branch 2 → 3 taken 1160139 times.
✗ Branch 2 → 11 not taken.
|
1160139 | std::stringstream name; |
| 153 |
1/2✓ Branch 3 → 4 taken 1160139 times.
✗ Branch 3 → 9 not taken.
|
1160139 | getName(name, withSize, ignorePublic, withAliases); |
| 154 |
1/2✓ Branch 4 → 5 taken 1160139 times.
✗ Branch 4 → 9 not taken.
|
2320278 | return name.str(); |
| 155 | 1160139 | } | |
| 156 | |||
| 157 | } // namespace spice::compiler | ||
| 158 |