forked from OSchip/llvm-project
Add llvm::all_of which wraps std::all_of.
This version doesn't need begin/end but can instead just take a type which has begin/end methods. Use this to replace an eligible foreach loop in LoopInfo found by David Blaikie in r237224. Reviewed by David Blaikie. llvm-svn: 237301
This commit is contained in:
parent
ab9fd035fd
commit
a264dc0933
|
@ -18,6 +18,7 @@
|
||||||
#define LLVM_ADT_STLEXTRAS_H
|
#define LLVM_ADT_STLEXTRAS_H
|
||||||
|
|
||||||
#include "llvm/Support/Compiler.h"
|
#include "llvm/Support/Compiler.h"
|
||||||
|
#include <algorithm> // for std::all_of
|
||||||
#include <cassert>
|
#include <cassert>
|
||||||
#include <cstddef> // for std::size_t
|
#include <cstddef> // for std::size_t
|
||||||
#include <cstdlib> // for qsort
|
#include <cstdlib> // for qsort
|
||||||
|
@ -327,6 +328,14 @@ void DeleteContainerSeconds(Container &C) {
|
||||||
C.clear();
|
C.clear();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/// Provide wrappers to std::all_of which take ranges instead of having to pass
|
||||||
|
/// being/end explicitly.
|
||||||
|
template<typename R, class UnaryPredicate>
|
||||||
|
bool all_of(R &&Range, UnaryPredicate &&P) {
|
||||||
|
return std::all_of(Range.begin(), Range.end(),
|
||||||
|
std::forward<UnaryPredicate>(P));
|
||||||
|
}
|
||||||
|
|
||||||
//===----------------------------------------------------------------------===//
|
//===----------------------------------------------------------------------===//
|
||||||
// Extra additions to <memory>
|
// Extra additions to <memory>
|
||||||
//===----------------------------------------------------------------------===//
|
//===----------------------------------------------------------------------===//
|
||||||
|
|
|
@ -65,11 +65,7 @@ bool Loop::isLoopInvariant(const Value *V) const {
|
||||||
/// hasLoopInvariantOperands - Return true if all the operands of the
|
/// hasLoopInvariantOperands - Return true if all the operands of the
|
||||||
/// specified instruction are loop invariant.
|
/// specified instruction are loop invariant.
|
||||||
bool Loop::hasLoopInvariantOperands(const Instruction *I) const {
|
bool Loop::hasLoopInvariantOperands(const Instruction *I) const {
|
||||||
for (auto &Op : I->operands())
|
return all_of(I->operands(), [this](Value *V) { return isLoopInvariant(V); });
|
||||||
if (!isLoopInvariant(Op))
|
|
||||||
return false;
|
|
||||||
|
|
||||||
return true;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/// makeLoopInvariant - If the given value is an instruciton inside of the
|
/// makeLoopInvariant - If the given value is an instruciton inside of the
|
||||||
|
|
Loading…
Reference in New Issue