mirror of
https://github.com/RPCS3/llvm.git
synced 2025-04-02 21:31:41 +00:00
[PM] Take more drastic measures to work around MSVC's failure on this
code. If this doesn't work and I can't find someone to help who has MSVC installed, I'll back everything out I guess. =[ git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@291661 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
3cf3d0849d
commit
6b834bb9ba
@ -75,6 +75,15 @@ public:
|
||||
}
|
||||
|
||||
protected:
|
||||
// FIXME: MSVC seems unable to handle a lambda argument to Invoke from within
|
||||
// the template, so we use a boring static function.
|
||||
static bool invalidateCallback(IRUnitT &IR, const PreservedAnalyses &PA,
|
||||
typename AnalysisManagerT::Invalidator &Inv) {
|
||||
auto PAC = PA.template getChecker<Analysis>();
|
||||
return !PAC.preserved() &&
|
||||
!PAC.template preservedSet<AllAnalysesOn<IRUnitT>>();
|
||||
}
|
||||
|
||||
/// Derived classes should call this in their constructor to set up default
|
||||
/// mock actions. (We can't do this in our constructor because this has to
|
||||
/// run after the DerivedT is constructed.)
|
||||
@ -82,14 +91,8 @@ protected:
|
||||
ON_CALL(static_cast<DerivedT &>(*this),
|
||||
run(_, _, testing::Matcher<ExtraArgTs>(_)...))
|
||||
.WillByDefault(Return(this->getResult()));
|
||||
auto InvalidateLambda = [](IRUnitT &IR, const PreservedAnalyses &PA,
|
||||
typename AnalysisManagerT::Invalidator &Inv) {
|
||||
auto PAC = PA.template getChecker<Analysis>();
|
||||
return !PAC.preserved() &&
|
||||
!PAC.template preservedSet<AllAnalysesOn<IRUnitT>>();
|
||||
};
|
||||
ON_CALL(static_cast<DerivedT &>(*this), invalidate(_, _, _))
|
||||
.WillByDefault(Invoke(InvalidateLambda));
|
||||
.WillByDefault(Invoke(&invalidateCallback));
|
||||
}
|
||||
};
|
||||
|
||||
|
Loading…
x
Reference in New Issue
Block a user