mirror of
https://github.com/RPCS3/llvm-mirror.git
synced 2024-11-23 11:13:28 +01:00
[LCG] Fix an assert in a on-scope-exit lambda that checked the contents
of the returned value. Checking the returned value from inside of a scoped exit isn't actually valid. It happens to work when NRVO fires and the stars align, which they reliably do with Clang but don't, for example, on MSVC builds. llvm-svn: 310547
This commit is contained in:
parent
7d8bec2d45
commit
35c2aa57f7
@ -1105,14 +1105,10 @@ LazyCallGraph::RefSCC::removeInternalRefEdge(Node &SourceN,
|
||||
// or we return new RefSCCs and this RefSCC is dead.
|
||||
verify();
|
||||
auto VerifyOnExit = make_scope_exit([&]() {
|
||||
if (Result.empty()) {
|
||||
// If we didn't replace our RefSCC with new ones, check that this one
|
||||
// remains valid.
|
||||
if (G)
|
||||
verify();
|
||||
} else {
|
||||
assert(!G && "A dead RefSCC should have its graph pointer nulled.");
|
||||
assert(SCCs.empty() && "A dead RefSCC should have no SCCs in it.");
|
||||
for (RefSCC *RC : Result)
|
||||
RC->verify();
|
||||
}
|
||||
});
|
||||
#endif
|
||||
|
||||
@ -1325,6 +1321,12 @@ LazyCallGraph::RefSCC::removeInternalRefEdge(Node &SourceN,
|
||||
SCCs.clear();
|
||||
SCCIndices.clear();
|
||||
|
||||
#ifndef NDEBUG
|
||||
// Verify the new RefSCCs we've built.
|
||||
for (RefSCC *RC : Result)
|
||||
RC->verify();
|
||||
#endif
|
||||
|
||||
// Return the new list of SCCs.
|
||||
return Result;
|
||||
}
|
||||
|
Loading…
Reference in New Issue
Block a user