Skip to content

Commit

Permalink
embedded: Don't emit SILProperties in embedded swift
Browse files Browse the repository at this point in the history
SILProperties are only needed for resilient builds.

Fixes a crash in IRGen
swiftlang#77682
  • Loading branch information
eeckstein committed Dec 3, 2024
1 parent 267ff07 commit 2d18f9f
Show file tree
Hide file tree
Showing 2 changed files with 16 additions and 4 deletions.
10 changes: 6 additions & 4 deletions lib/IRGen/GenDecl.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -1224,10 +1224,12 @@ void IRGenerator::emitGlobalTopLevel(
}
}

// Emit property descriptors.
for (auto &prop : PrimaryIGM->getSILModule().getPropertyList()) {
CurrentIGMPtr IGM = getGenModule(prop.getDecl()->getInnermostDeclContext());
IGM->emitSILProperty(&prop);
if (!SIL.getASTContext().LangOpts.hasFeature(Feature::Embedded)) {
// Emit property descriptors.
for (auto &prop : PrimaryIGM->getSILModule().getPropertyList()) {
CurrentIGMPtr IGM = getGenModule(prop.getDecl()->getInnermostDeclContext());
IGM->emitSILProperty(&prop);
}
}

// Emit differentiability witnesses.
Expand Down
10 changes: 10 additions & 0 deletions test/embedded/keypath-crash.swift
Original file line number Diff line number Diff line change
Expand Up @@ -42,4 +42,14 @@ public struct State<Wrapped> {
}
}

public struct S<T> {
public private(set) subscript(x: Int) -> Int {
get {
return 27
}
mutating set {
}
}
}

// CHECK: define {{.*}}@main(

0 comments on commit 2d18f9f

Please sign in to comment.