1
0
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:
Chandler Carruth 2017-08-10 03:05:21 +00:00
parent 7d8bec2d45
commit 35c2aa57f7

View File

@ -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;
}