Skip to content

Commit 6db11b6

Browse files
authored
Merge pull request #82347 from drexin/wip-153681688
[IRGen] Fix placeholder logic for emission of conditionally inverted …
2 parents e4fb254 + 5ec5820 commit 6db11b6

File tree

2 files changed

+12
-3
lines changed

2 files changed

+12
-3
lines changed

lib/IRGen/GenMeta.cpp

Lines changed: 4 additions & 3 deletions
Original file line numberDiff line numberDiff line change
@@ -1393,12 +1393,13 @@ namespace {
13931393

13941394
// Create placeholders for the counts of the conditional requirements
13951395
// for each conditional conformance to a supressible protocol.
1396-
unsigned numProtocols = countBitsUsed(protocols.rawBits());
1396+
unsigned numProtocols = 0;
13971397
using PlaceholderPosition =
13981398
ConstantAggregateBuilderBase::PlaceholderPosition;
13991399
SmallVector<PlaceholderPosition, 2> countPlaceholders;
1400-
for (unsigned i : range(0, numProtocols)) {
1401-
(void)i;
1400+
for (auto kind : protocols) {
1401+
(void)kind;
1402+
numProtocols++;
14021403
countPlaceholders.push_back(
14031404
B.addPlaceholderWithSize(IGM.Int16Ty));
14041405
}
Lines changed: 8 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,8 @@
1+
// RUN: %target-swift-frontend %s -target %target-swift-5.9-abi-triple -emit-ir
2+
3+
public enum Enum<T : ~Escapable> : ~Escapable {
4+
case none
5+
case some(T)
6+
}
7+
8+
extension Enum: Escapable where T: Escapable {}

0 commit comments

Comments
 (0)